首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >sqlfiddle中的MySQL语法错误

sqlfiddle中的MySQL语法错误
EN

Stack Overflow用户
提问于 2016-03-27 13:04:45
回答 1查看 608关注 0票数 0

虽然我认为下面的mysql代码的语法按照文档是正确的,但是SQLFiddle会弹出一个错误,而且由于我认为出现错误的行的语法是正确的,我不知道该更改什么。

代码语言:javascript
复制
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行附近使用的正确语法

请帮我解决这个问题。

EN

回答 1

Stack Overflow用户

发布于 2016-03-27 13:11:40

正如在文档中所解释的,CURRENT_TIMESTAMP的同义词被允许作为默认值。SYSDATE()不是这样的同义词。您可以使用NOW() (或其他几个构造)。

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

代码语言:javascript
复制
created_on DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36247654

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档