2012-02-28 225 views
0

我查看了建议的代码,找不到解决问题的答案,因此我要求离开。MySQL错误 - SQLSTATE [42000]:语法错误或访问冲突:1064

我正在使用MAMP v2.0.5,MySQL v5.5.9,PHP v5.3.6(根据MAMP,v5.3.8根据OS X)和FuelPHP v1.1,并且对我正在通过教程。部分教程需要使用“石油”来执行迁移以更新项目。定义了一个表后,迁移应用SQL来生成表。当我这样做时,我得到了上述错误。查看了生成的代码后,我找不到任何错误(也许我错过了一些明显的东西)。我正在使用PDO,并且检查了我的sql_mode = '',它的确如此。从命令行和phpMyAdmin运行MySQL查询证实了这一点。我认为这是一个MySQL错误,而不是FuelPHP/oil的问题。有人有任何建议吗?

生成的SQL:

CREATE TABLE IF NOT EXISTS `users` (
    `id` int(11) NOT NULL AUTO_INCREMENT, 
    `username` varhcar(50) NOT NULL, 
    `password` varchar(255) NOT NULL, 
    `group` int(11) NOT NULL, 
    `email` varchar(255) NOT NULL, 
    `last_login` int(11) NOT NULL, 
    `login_hash` varchar(255) NOT NULL, 
    `profile_fields` text NOT NULL, 
    `created_at` int(11) NOT NULL, 
    `updated_at` int(11) NOT NULL, 
    PRIMARY KEY `id` (`id`) 
) DEFAULT CHARACTER SET utf8; 

错误:

bash:blog me$ oil refine migrate 
Error - SQLSTATE[42000]: Syntax error or access violation: 1064 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 'varhcar(50) NOT NULL, 
    `password` varchar(255) NOT NULL, 
    `group` int(11) NOT NU' at line 3 with query: "CREATE TABLE IF NOT EXISTS `users` (
    `id` int(11) NOT NULL AUTO_INCREMENT, 
    `username` varhcar(50) NOT NULL, 
    `password` varchar(255) NOT NULL, 
    `group` int(11) NOT NULL, 
    `email` varchar(255) NOT NULL, 
    `last_login` int(11) NOT NULL, 
    `login_hash` varchar(255) NOT NULL, 
    `profile_fields` text NOT NULL, 
    `created_at` int(11) NOT NULL, 
    `updated_at` int(11) NOT NULL, 
    PRIMARY KEY `id` (`id`) 
) DEFAULT CHARACTER SET utf8;" in COREPATH/classes/database/pdo/connection.php on line 137 
+0

尽管我刚刚注意到“group”是一个保留字,把它改为“user_group”,但我仍然得到相同的错误。 – 2012-02-28 00:30:12

+0

还有一点不需要修复,因为MySQL会“自动修正”它。 'PRIMARY KEY id(id)'与'PRIMARY KEY(id)'实际上是一样的。您无法选择主键的名称。默认情况下,它被称为“PRIMARY”。 – 2012-03-25 21:37:30

回答

2

你犯了一个错字:

`username` varhcar(50) NOT NULL, 

应该是:

`username` varchar(50) NOT NULL, 
+0

谢谢。男孩我觉得自己像一个笨蛋,我一直在看那几个小时! – 2012-02-28 00:32:33

+1

当mysql给出正确的语法错误* ....在'_ _'*附近使用时,只需检查紧接在_ _之前的部分中的查询或_ _中的第一个字符。错误日志有帮助你 – 2012-02-28 00:35:12

+0

谢谢。在了解错误时,我特别不好。尽管很容易发现,但您的帮助非常感谢。 – 2012-02-28 00:38:54

相关问题