我正在尝试执行一个简单的 MySQL 查询,如下所示:
INSERT INTO user_details (username, location, key)
VALUES ('Tim', 'Florida', 42)
但我收到以下错误:
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 'key) VALUES ('Tim', 'Florida', 42)'
at line 1
我该如何解决这个问题?
问题
在 MySQL 中,SELECT
、INSERT
、DELETE
等某些字是保留字。由于它们具有特殊含义,因此只要您将它们用作表名、列名或其他类型的标识符,MySQL 就会将其视为语法错误 - 除非您用反引号将标识符括起来。
如官方文档中所述,在 10.2 Schema Object Names 部分(强调):
Certain objects within MySQL, including database, table, index, column, alias, view, stored procedure, partition, tablespace, and other object names are known as identifiers.
...
If an identifier contains special characters or is a reserved word, you must quote it whenever you refer to it.
...
The identifier quote character is the backtick ("`
"):
关键字和保留字的完整列表可以在 10.3 Keywords and Reserved Words 部分找到.在该页面中,后面跟有“(R)”的词是保留词。下面列出了一些保留字,包括许多容易导致此问题的字。
- 添加
- 和
- 之前
- 通过
- 调用
- 案例
- 条件
- 删除
- 描述
- 描述
- 来自
- 组
- 在
- 索引
- 插入
- 间隔
- 是
- 关键
- 赞
- 限制
- 长
- 匹配
- 没有
- 选项
- 或
- 订购
- 分区
- 排名
- 引用资料
- 选择
- 表格
- 致
- 更新
- 哪里
解决方案
你有两个选择。
1。不要使用保留字作为标识符
最简单的解决方案就是避免使用保留字作为标识符。您可能会为您的列找到另一个不是保留字的合理名称。
这样做有几个好处:
它消除了您或使用您的数据库的其他开发人员由于忘记(或不知道)特定标识符是保留字而意外写入语法错误的可能性。 MySQL 中有很多保留字,大多数开发人员不太可能知道所有的保留字。如果一开始就不使用这些词,就可以避免给自己或 future 的开发者留下陷阱。
引用标识符的方式因 SQL 方言而异。虽然 MySQL 默认使用反引号来引用标识符,但符合 ANSI 标准的 SQL(实际上是 ANSI SQL 模式下的 MySQL,如 here 所述)使用双引号来引用标识符。因此,使用反引号引用标识符的查询不太容易移植到其他 SQL 方言。
纯粹是为了减少将来犯错的风险,这通常是比反引号引用标识符更明智的做法。
2。使用反引号
如果无法重命名表或列,请将有问题的标识符用反引号 (`
) 包裹起来,如之前引用自 10.2 Schema Object Names 中所述.
演示用法的示例(取自 10.3 Keywords and Reserved Words ):
mysql> <strong>CREATE TABLE interval (begin INT, end INT);</strong>
ERROR 1064 (42000): You have an error in your SQL syntax.
near 'interval (begin INT, end INT)'
mysql> <strong>CREATE TABLE `interval` (begin INT, end INT);</strong>
Query OK, 0 rows affected (0.01 sec)
同样,问题的查询可以通过将关键字 key
包裹在反引号中来修复,如下所示:
INSERT INTO user_details (username, location, `key`)
VALUES ('Tim', 'Florida', 42)"; ^ ^