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 服务器版本相对应的手册,以在第 14 行的 'SYSDATE() NOT NULL, updated_on DATETIME(6), is_active CHAR(1) DEFAULT '1' 附近使用正确的语法

请帮我解决这个问题。

4

1 回答 1

0

文档CURRENT_TIMESTAMP中所述,默认值允许使用 同义词。SYSDATE()不是这样的同义词。您可以使用NOW()(或其他几种构造)。

因此,该列的正确语法是:

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