我查看了建议的代码,但找不到解决问题的答案,所以我问了。
我正在使用 MAMP v2.0.5、MySQL v5.5.9、PHP v5.3.6(根据 MAMP,根据 OS X 为 v5.3.8)和 FuelPHP v1.1,并且是框架的新手,我正在学习教程。本教程的一部分需要使用“石油”来执行迁移以更新项目。定义表后,迁移应用 SQL 生成表。当我这样做时,我收到上述错误。查看生成的代码后,我找不到任何错误(也许我遗漏了一些明显的东西)。我正在使用 PDO 并且还检查了 my sql_mode = ''
,它确实如此。从命令行运行 MySQL 查询,phpMyAdmin 确认了这一点。我认为这是一个 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