mysql - MySQL中使用保留字作为表名或列名导致的语法错误

标签 mysql reserved-words

<分区>

我正在尝试执行一个简单的 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 中,SELECTINSERTDELETE 等某些字是保留字。由于它们具有特殊含义,因此只要您将它们用作表名、列名或其他类型的标识符,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)";               ^   ^

关于mysql - MySQL中使用保留字作为表名或列名导致的语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44380794/

相关文章:

mysql - SQL批量删除两个标记之间的文本内容

php - 通过或使用 PHP 的 MySQL GROUP?

python - Django 通过字段选择对字段中的唯一项目进行计数并按父字段进行分组

java - 当直观的名称是保留关键字时,如何简洁地命名方法/变量?

apache-flex - 是否有保留的 FlashVars 名称列表?

c - 自动交互编程

javascript - Node.js mysql 查询传递给 async.waterfall 中的下一个函数

php - 插入语句不起作用。从一张 table 转移到另一张 table

c++ - 保留的函数名可以重载吗?

php - 您的 SQL 语法有误 - 靠近“左”)