【问题标题】:Error in table definition syntax表定义语法错误
【发布时间】:2014-02-18 02:01:52
【问题描述】:

ERROR 1064 (42000):您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 6 行的“desc text)”附近使用正确的语法

我的查询看起来像这样...

CREATE TABLE products (
    title varchar(100),
    img varchar(100),
    price int,
    type varchar(10),
    desc text);

我确信我在深夜忽略了这件事很愚蠢,但对于我的生活,我无法弄清楚为什么它不会通过。我对这一切还是很陌生,但我的列名称是否与数据类型或 SQL 函数的名称有冲突?

【问题讨论】:

  • 保持自己和他人的理智。不要在表/列定义中使用保留字

标签: mysql sql syntax syntax-error


【解决方案1】:

DESC 是一个reserved word。如果要将其用作列标识符,则必须将其包装在刻度中

CREATE TABLE products (
  title varchar(100),
  img varchar(100),
  price int,
  type varchar(10),
  `desc` text
);

【讨论】:

  • 谢谢你的链接,我以为有保留字,但由于某种原因我找不到。
【解决方案2】:

desc 是一个关键字。用反引号转义它或使用不同的字段名称。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2010-10-18
    • 2014-09-13
    • 2020-06-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多