MySQL错误 - SQLSTATE [42000]:语法错误或访问冲突:1064

时间:2012-02-28 00:26:01

标签: mysql pdo fuelphp

我查看了建议的代码,找不到解决问题的答案,所以我要求离开。

我正在使用MAMP v2.0.5,MySQL v5.5.9,PHP v5.3.6(根据MAMP,v5.3.8根据OS X)和FuelPHP v1.1,并且是我正在通过教程工作的框架的新手。本教程的一部分需要使用“oil”来执行迁移以更新项目。定义了表后,迁移将应用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

1 个答案:

答案 0 :(得分:3)

你写了一个错字:

`username` varhcar(50) NOT NULL,

应该是:

`username` varchar(50) NOT NULL,