0

次のmysqlコードの構文はドキュメントに従って正しいと思いますが、SQLFiddleはエラーをポップアップし、エラーを発生させる行の構文は正しいと思うので、何を変更すればよいかわかりません。

CREATE TABLE students
(
student_id DECIMAL(38) NOT NULL,
username VARCHAR(30),
email VARCHAR(80),
password VARCHAR(30),
f_name VARCHAR(30),
l_name VARCHAR(30),
bio VARCHAR(350),
dp VARCHAR(15),
is_suspended CHAR(1) DEFAULT '0' NOT NULL,
suspension_reason VARCHAR(150),
role_id DECIMAL(38) NOT NULL,
created_on DATETIME(6) DEFAULT SYSDATE() NOT NULL,
updated_on DATETIME(6),
is_active CHAR(1) DEFAULT '1' NOT NULL,
city VARCHAR(15) NOT NULL,
state VARCHAR(15) NOT NULL,
zip VARCHAR(6) NOT NULL,
b_day DATETIME,
CONSTRAINT students_id_pk PRIMARY KEY(student_id),
CONSTRAINT students_role_id_fk FOREIGN KEY(role_id) REFERENCES user_role(role_id),
CONSTRAINT students_username_uq UNIQUE(username),
CONSTRAINT students_email_uq UNIQUE(email)
);

SQL 構文にエラーがあります。使用する正しい構文については、MySQL サーバーのバージョンに対応するマニュアルを確認してください。

この問題の解決を手伝ってください。

4

1 に答える 1

0

ドキュメントで説明されてCURRENT_TIMESTAMPいるように、デフォルト値には 同義語が許可されています。SYSDATE()はそのような同義語ではありません。NOW()(または他のいくつかの構成要素)を使用できます。

したがって、その列の正しい構文は次のとおりです。

created_on DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
于 2016-03-27T13:11:40.763 に答える