虽然我认为下面的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服务器版本对应的手册,以获得在“SYSDATE() NULL,updated_on DATETIME(6),is_active CHAR(1)默认的”1“在第14行附近使用的正确语法
请帮我解决这个问题。
发布于 2016-03-27 13:11:40
正如在文档中所解释的,CURRENT_TIMESTAMP的同义词被允许作为默认值。SYSDATE()不是这样的同义词。您可以使用NOW() (或其他几个构造)。
因此,该列的正确语法是:
created_on DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,https://stackoverflow.com/questions/36247654
复制相似问题