我不确定我的创建表在这里有什么问题。继续给我错误
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;
答案 0 :(得分:3)
character
和from
是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)
两个问题:
这应该有效:
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;
希望得到这个帮助。