发布网友 发布时间:2022-04-13 03:48
共3个回答
懂视网 时间:2022-04-13 08:10
最近在将数据从Oracle迁移到MySQL的过程中,遇到一些问题,其中就包括关键字。下面这篇文章主要给大家介绍了MySQL 5.7中的关键字与保留字的相关资料,文中介绍的非常详细,需要的朋友可以参考学习,下面来一起看看吧。前言
MySQL和Oracle的关键字还是不尽相同的,在Oracle数据库中,我们的数据表中定义了大量的code字段用来表示主键,但是在MySQL中code是关键字,使用以前的处理方法就有些“水土不服”。
下面我们来了解一下MySQL中的关键字和保留字。
什么是关键字和保留字
关键字是指在SQL中有意义的字。 某些关键字(例如SELECT,DELETE或BIGINT)是保留的,需要特殊处理才能用作表和列名称等标识符。 这一点对于内置函数的名称也适用。
如何使用关键字和保留字
非保留关键字允许作为标识符,不需要加引号。 如果您要适用保留字作为标识符,就必须适用引号。
举个例子,BEGIN和END是关键字,但不是保留字,因此它们用作标识符不需要引号。 INTERVAL是保留关键字,必须加上引号才能用作标识符。
mysql> mysql> use hoegh; Database changed mysql> mysql> CREATE TABLE interval (begin INT, end INT); ERROR 1064 (42000): mysql> mysql> CREATE TABLE `interval` (begin INT, end INT); Query OK, 0 rows affected (0.42 sec) mysql> mysql> show create table `interval`; +----------+--------------------------------------------------------- | Table | Create Table +----------+--------------------------------------------------------- | interval | CREATE TABLE `interval` ( `begin` int(11) DEFAULT NULL, `end` int(11) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=latin1 | +----------+--------------------------------------------------------- 1 row in set (0.00 sec) mysql>
我们看到,第一条语句中表名使用了保留字interval,执行失败;
第二条语句对interval加了引号,执行成功。
在这里需要注意的是,引号必须是反引号,而非单引号。否则会报错,如下所示:
mysql> mysql> drop table `interval`;--使用反引号 Query OK, 0 rows affected (0.11 sec) mysql> mysql> create table 'interval' (begin INT, end INT);--使用单引号,报错 ERROR 1064 (42000): mysql>
有一个例外
如果标识符在限定名称(数据库名)的句点之后,即使是保留关键字也不需要引号。
我们以hoegh数据库为例,如果表名写为hoegh.interval就不需要对保留字interval加引号了。
mysql> mysql> create table hoegh.interval (begin INT, end INT); Query OK, 0 rows affected (0.19 sec) mysql> mysql> show create table hoegh.interval; +----------+--------------------------------------------------------- | Table | Create Table +----------+--------------------------------------------------------- | interval | CREATE TABLE `interval` ( `begin` int(11) DEFAULT NULL, `end` int(11) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=latin1 | +----------+--------------------------------------------------------- 1 row in set (0.00 sec) mysql>
关于使用内置函数名称
允许内置函数的名称可以作为标识符,但最好谨慎使用。例如,COUNT作为列名称是合法的。但是,默认情况下,在函数名和后面的(之间的函数调用中不允许有空格。这个限制使解析器能够区分名称是用于函数调用还是用在非函数上下文中。
附录
在某些时候,您可能需要升级到更高版本,因此最好查看一下未来的保留字。您可以在涵盖更高版本的MySQL的手册中找到这些。对于表中的大多数保留字,在标准SQL中禁止作为列或表的名称(例如,GROUP)。其中一些保留字,是由于MySQL需要它们并使用一个yacc解析器。
以下列出三张表格:
第一个表格10.2显示MySQL 5.7中的关键字和保留字。保留的关键字标记为(R)。此外,_FILENAME是保留的。
第二个表格10.3显示MySQL 5.7相比5.6版本新增的保留字。
第三个表格10.4显示MySQL 5.7相比5.6版本删除的保留字。
Table 10.2 Keywords and Reserved Words in MySQL 5.7
ACCESSIBLE (R) | ACCOUNT[a] | ACTION | |||||||||||||||||||||||||||||||||||||||||||||||
ADD (R) | AFTER | AGAINST | |||||||||||||||||||||||||||||||||||||||||||||||
AGGREGATE | ALGORITHM | ALL (R) | |||||||||||||||||||||||||||||||||||||||||||||||
ALTER (R) | ALWAYS[b] | ANALYSE | |||||||||||||||||||||||||||||||||||||||||||||||
ANALYZE (R) | AND (R) | ANY | |||||||||||||||||||||||||||||||||||||||||||||||
AS (R) | ASC (R) | ASCII | |||||||||||||||||||||||||||||||||||||||||||||||
ASENSITIVE (R) | AT | AUTOEXTEND_SIZE | |||||||||||||||||||||||||||||||||||||||||||||||
AUTO_INCREMENT | AVG | AVG_ROW_LENGTH | |||||||||||||||||||||||||||||||||||||||||||||||
BACKUP | BEFORE (R) | BEGIN | |||||||||||||||||||||||||||||||||||||||||||||||
BETWEEN (R) | BIGINT (R) | BINARY (R) | |||||||||||||||||||||||||||||||||||||||||||||||
BINLOG | BIT | BLOB (R) | |||||||||||||||||||||||||||||||||||||||||||||||
BLOCK | BOOL | BOOLEAN | |||||||||||||||||||||||||||||||||||||||||||||||
BOTH (R) | BTREE | BY (R) | |||||||||||||||||||||||||||||||||||||||||||||||
BYTE | CACHE | CALL (R) | |||||||||||||||||||||||||||||||||||||||||||||||
CASCADE (R) | CASCADED | CASE (R) | |||||||||||||||||||||||||||||||||||||||||||||||
CATALOG_NAME | CHAIN | CHANGE (R) | |||||||||||||||||||||||||||||||||||||||||||||||
CHANGED | CHANNEL[c] | CHAR (R) | |||||||||||||||||||||||||||||||||||||||||||||||
CHARACTER (R) | CHARSET | CHECK (R) | |||||||||||||||||||||||||||||||||||||||||||||||
CHECKSUM | CIPHER | CLASS_ORIGIN | |||||||||||||||||||||||||||||||||||||||||||||||
CLIENT | CLOSE | COALESCE | |||||||||||||||||||||||||||||||||||||||||||||||
CODE | COLLATE (R) | COLLATION | |||||||||||||||||||||||||||||||||||||||||||||||
COLUMN (R) | COLUMNS | COLUMN_FORMAT | |||||||||||||||||||||||||||||||||||||||||||||||
COLUMN_NAME | COMMENT | COMMIT | |||||||||||||||||||||||||||||||||||||||||||||||
COMMITTED | COMPACT | COMPLETION | |||||||||||||||||||||||||||||||||||||||||||||||
COMPRESSED | COMPRESSION[d] | CONCURRENT | |||||||||||||||||||||||||||||||||||||||||||||||
CONDITION (R) | CONNECTION | CONSISTENT | |||||||||||||||||||||||||||||||||||||||||||||||
CONSTRAINT (R) | CONSTRAINT_CATALOG | CONSTRAINT_NAME | |||||||||||||||||||||||||||||||||||||||||||||||
CONSTRAINT_SCHEMA | CONTAINS | CONTEXT | |||||||||||||||||||||||||||||||||||||||||||||||
CONTINUE (R) | CONVERT (R) | CPU | |||||||||||||||||||||||||||||||||||||||||||||||
CREATE (R) | CROSS (R) | CUBE | |||||||||||||||||||||||||||||||||||||||||||||||
CURRENT | CURRENT_DATE (R) | CURRENT_TIME (R) | |||||||||||||||||||||||||||||||||||||||||||||||
CURRENT_TIMESTAMP (R) | CURRENT_USER (R) | CURSOR (R) | |||||||||||||||||||||||||||||||||||||||||||||||
CURSOR_NAME | DATA | DATABASE (R) | |||||||||||||||||||||||||||||||||||||||||||||||
DATABASES (R) | DATAFILE | DATE | |||||||||||||||||||||||||||||||||||||||||||||||
DATETIME | DAY | DAY_HOUR (R) | |||||||||||||||||||||||||||||||||||||||||||||||
DAY_MICROSECOND (R) | DAY_MINUTE (R) | DAY_SECOND (R) | |||||||||||||||||||||||||||||||||||||||||||||||
DEALLOCATE | DEC (R) | DECIMAL (R) | |||||||||||||||||||||||||||||||||||||||||||||||
DECLARE (R) | DEFAULT (R) | DEFAULT_AUTH | |||||||||||||||||||||||||||||||||||||||||||||||
DEFINER | DELAYED (R) | DELAY_KEY_WRITE | |||||||||||||||||||||||||||||||||||||||||||||||
DELETE (R) | DESC (R) | DESCRIBE (R) | |||||||||||||||||||||||||||||||||||||||||||||||
DES_KEY_FILE | DETERMINISTIC (R) | DIAGNOSTICS | |||||||||||||||||||||||||||||||||||||||||||||||
DIRECTORY | DISABLE | DISCARD | |||||||||||||||||||||||||||||||||||||||||||||||
DISK | DISTINCT (R) | DISTINCTROW (R) | |||||||||||||||||||||||||||||||||||||||||||||||
p (R) | DO | DOUBLE (R) | |||||||||||||||||||||||||||||||||||||||||||||||
DROP (R) | DUAL (R) | DUMPFILE | |||||||||||||||||||||||||||||||||||||||||||||||
DUPLICATE | DYNAMIC | EACH (R) | |||||||||||||||||||||||||||||||||||||||||||||||
ELSE (R) | ELSEIF (R) | ENABLE | |||||||||||||||||||||||||||||||||||||||||||||||
ENCLOSED (R) | ENCRYPTION[e] | END | |||||||||||||||||||||||||||||||||||||||||||||||
ENDS | ENGINE | ENGINES | |||||||||||||||||||||||||||||||||||||||||||||||
ENUM | ERROR | ERRORS | |||||||||||||||||||||||||||||||||||||||||||||||
ESCAPE | ESCAPED (R) | EVENT | |||||||||||||||||||||||||||||||||||||||||||||||
EVENTS | EVERY | EXCHANGE | |||||||||||||||||||||||||||||||||||||||||||||||
EXECUTE | EXISTS (R) | EXIT (R) | |||||||||||||||||||||||||||||||||||||||||||||||
EXPANSION | EXPIRE | EXPLAIN (R) | |||||||||||||||||||||||||||||||||||||||||||||||
EXPORT | EXTENDED | EXTENT_SIZE | |||||||||||||||||||||||||||||||||||||||||||||||
FALSE (R) | FAST | FAULTS | |||||||||||||||||||||||||||||||||||||||||||||||
FETCH (R) | FIELDS | FILE | |||||||||||||||||||||||||||||||||||||||||||||||
FILE_BLOCK_SIZE[f] | FILTER[g] | FIRST | |||||||||||||||||||||||||||||||||||||||||||||||
FIXED | FLOAT (R) | FLOAT4 (R) | |||||||||||||||||||||||||||||||||||||||||||||||
FLOAT8 (R) | FLUSH | FOLLOWS[h] | |||||||||||||||||||||||||||||||||||||||||||||||
FOR (R) | FORCE (R) | FOREIGN (R) | |||||||||||||||||||||||||||||||||||||||||||||||
FORMAT | FOUND | FROM (R) | |||||||||||||||||||||||||||||||||||||||||||||||
FULL | FULLTEXT (R) | FUNCTION | |||||||||||||||||||||||||||||||||||||||||||||||
GENERAL | GENERATED[i] (R) | GEOMETRY | |||||||||||||||||||||||||||||||||||||||||||||||
GEOMETRYCOLLECTION | GET (R) | GET_FORMAT | |||||||||||||||||||||||||||||||||||||||||||||||
GLOBAL | GRANT (R) | GRANTS | |||||||||||||||||||||||||||||||||||||||||||||||
GROUP (R) | GROUP_REPLICATION[j] | HANDLER | |||||||||||||||||||||||||||||||||||||||||||||||
HASH | HAVING (R) | HELP | |||||||||||||||||||||||||||||||||||||||||||||||
HIGH_PRIORITY (R) | HOST | HOSTS | |||||||||||||||||||||||||||||||||||||||||||||||
HOUR | HOUR_MICROSECOND (R) | HOUR_MINUTE (R) | |||||||||||||||||||||||||||||||||||||||||||||||
HOUR_SECOND (R) | IDENTIFIED | IF (R) | |||||||||||||||||||||||||||||||||||||||||||||||
IGNORE (R) | IGNORE_SERVER_IDS | IMPORT | |||||||||||||||||||||||||||||||||||||||||||||||
IN (R) | INDEX (R) | INDEXES | |||||||||||||||||||||||||||||||||||||||||||||||
INFILE (R) | INITIAL_SIZE | INNER (R) | |||||||||||||||||||||||||||||||||||||||||||||||
INOUT (R) | INSENSITIVE (R) | INSERT (R) | |||||||||||||||||||||||||||||||||||||||||||||||
INSERT_METHOD | INSTALL | INSTANCE[k] | |||||||||||||||||||||||||||||||||||||||||||||||
INT (R) | INT1 (R) | INT2 (R) | |||||||||||||||||||||||||||||||||||||||||||||||
INT3 (R) | INT4 (R) | INT8 (R) | |||||||||||||||||||||||||||||||||||||||||||||||
INTEGER (R) | INTERVAL (R) | INTO (R) | |||||||||||||||||||||||||||||||||||||||||||||||
INVOKER | IO | IO_AFTER_GTIDS (R) | |||||||||||||||||||||||||||||||||||||||||||||||
IO_BEFORE_GTIDS (R) | IO_THREAD | IPC | |||||||||||||||||||||||||||||||||||||||||||||||
IS (R) | ISOLATION | ISSUER | |||||||||||||||||||||||||||||||||||||||||||||||
ITERATE (R) | JOIN (R) | JSON[l] | |||||||||||||||||||||||||||||||||||||||||||||||
KEY (R) | KEYS (R) | KEY_BLOCK_SIZE | |||||||||||||||||||||||||||||||||||||||||||||||
KILL (R) | LANGUAGE | LAST | 热心网友 时间:2022-04-13 05:18 关键字(key words)和保留字(reserved words)都是指C语言里规定不能在代码中用作标志符的字,但是在宏定义中是可以使用关键字的,比如 #define void int 二者只是叫法不同,概念上是统一回事。 热心网友 时间:2022-04-13 06:36 是一个概念。声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
懂视 51dongshi.com 版权所有
Copyright © 2019-2024 |