无法创建SQL表[SQL]

时间:2012-03-05 17:46:48

标签: mysql sql

我不确定我的创建表在这里有什么问题。继续给我错误

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that 
    corresponds to your MySQL server version for the right syntax to use 
    near 'character
(
character_id VarChar(15) PRIMARY KEY,
name VarChar(30) NOT NULL,
sex' at line 1

我没有看到任何错误?

CREATE TABLE character
(
character_id VarChar(15) PRIMARY KEY,
name VarChar(30) NOT NULL,
sex VarChar(7) NOT NULL,
age INT NOT NULL,
hair VarChar(10) NOT NULL,
eye VarChar(10) NOT NULL,
skin VarChar(12) NOT NULL,
body VarChar(12) NOT NULL,
from VarChar(20) NOT NULL
) engine=innobd;

4 个答案:

答案 0 :(得分:3)

characterfrom是MySQL中的保留字:http://dev.mysql.com/doc/refman/5.5/en/reserved-words.html

要使用保留字作为字段/表格标识符,您必须使用反引号引用它:

create table `character` (
...
body VarChar(12) NOT NULL,
`from` VarChar(20) NOT NULL
...

答案 1 :(得分:0)

来自和字符都是数据库供应商保留的特殊字。例如,尝试命名列“限制”,您将得到相同的结果。从重新命名表格和列,您的问题就会消失。

答案 2 :(得分:0)

CREATE TABLE 'character'
(
character_id VarChar(15) PRIMARY KEY,
name VarChar(30) NOT NULL,
sex VarChar(7) NOT NULL,
age INT NOT NULL,
hair VarChar(10) NOT NULL,
eye VarChar(10) NOT NULL,
skin VarChar(12) NOT NULL,
body VarChar(12) NOT NULL,
from VarChar(20) NOT NULL
) engine=innobd;

您正在尝试使用保留字,因此您需要在表名中添加反引号,我的建议是更改表名,并避免使用保留字

答案 3 :(得分:0)

两个问题:

  1. 表名“character”应为字符,字符为保留字
  2. 字段名称“from”应与SQL关键字FROM
  3. 不同

    这应该有效:

    CREATE TABLE characters
    (
    character_id VarChar(15) PRIMARY KEY,
    name VarChar(30) NOT NULL,
    sex VarChar(7) NOT NULL,
    age INT NOT NULL,
    hair VarChar(10) NOT NULL,
    eye VarChar(10) NOT NULL,
    skin VarChar(12) NOT NULL,
    body VarChar(12) NOT NULL,
    fromX VarChar(20) NOT NULL
    ) engine=innobd;
    

    希望得到这个帮助。