【问题标题】:MySQL Error - SQLSTATE [42000]: Syntax error or access violation: 1064 [closed]MySQL错误-SQLSTATE [42000]:语法错误或访问冲突:1064 [关闭]
【发布时间】:2012-02-28 00:26:00
【问题描述】:

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

我正在使用 MAMP v2.0.5、MySQL v5.5.9、PHP v5.3.6(根据 MA​​MP,根据 OS X 为 v5.3.8)和 FuelPHP v1.1,并且是框架新手,我正在学习教程.本教程的一部分需要使用“石油”来执行迁移以更新项目。定义表后,迁移应用 SQL 生成表。当我这样做时,我收到上述错误。查看生成的代码后,我找不到任何错误(也许我遗漏了一些明显的东西)。我正在使用 PDO,并且还检查了我的 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

【问题讨论】:

  • 虽然我刚刚注意到 "group" 是一个保留字,但将其更改为 "user_group" 我仍然得到同样的错误。
  • 还有一点不需要修复,因为 MySQL 会“自动更正”它。 PRIMARY KEY id (id)PRIMARY KEY (id) 完全一样。您不能选择主键的名称。默认情况下,它称为PRIMARY

标签: mysql pdo fuelphp


【解决方案1】:

你打错了:

`username` varhcar(50) NOT NULL,

应该是:

`username` varchar(50) NOT NULL,

【讨论】:

  • 谢谢。男孩,我觉得自己像个笨蛋,我已经看了好几个小时了!
  • 当 mysql 给出错误 *.... 以便在 '' * 附近使用正确的语法时,只需检查您在 ,或 中的第一个字符。错误日志可以帮助您
  • 谢谢。在理解错误时,我特别糟糕。非常感谢您的帮助,尽管很容易发现。
  • 有一个campaign to clean up Stack Overflow 通过删除这些与错字相关的问题,我们真的可以使用您的帮助!你介意在这个问题上投下密切的一票吗?
  • 它们有什么区别?
猜你喜欢
  • 2020-01-01
  • 1970-01-01
  • 2018-07-02
  • 2022-01-25
  • 2015-10-12
  • 1970-01-01
  • 1970-01-01
  • 2017-10-29
相关资源
最近更新 更多