1.注释符
SQL 注释是用来在 SQL 语句中添加对代码的解释说明。SQL 支持两种类型的注释符号。
单行注释:使用两个连续的减号(–)表示。减号后面的内容将被视为注释,直到该行结束。
代码语言:javascript复制SELECT column1, column2
FROM table
-- This is a single-line comment
WHERE condition;
多行注释:使用/* 注释内容*/
的格式表示。注释内容位于 /* 和 */ 之间,可以跨越多行。
SELECT column1, column2
FROM table
/* This is a
multi-line comment */
WHERE condition;
MySQL 除了支持上面 SQL 标准规定的两种注释方式,还支持使用 # 进行单行注释。因为 # 不是 SQL 标准规定的注释方式,所以并不是所有数据库都支持。
2.字符串符
在 SQL 标准中,字符串使用单引号(')表示,而不是双引号(")。
但对于主流的数据库,都支持双引号表示字符串,如 Oracle、MySQL 和 SQL Server 等。
如果字符串中包含单引号该如何表示呢?
在 SQL 中,如果要表示一个带有单引号的字符串有多种方式。
可以使用反斜杠()进行转移,也可以使用单引号进行转义,即使用两个单引号来表示一个单引号。
代码语言:javascript复制SELECT 'It's a beautiful day';
SELECT 'It''s a beautiful day';
因为 MySQL 支持使用双引号表示字符串,所以还可以使用双引号表示一个包含单引号的字符串。
代码语言:javascript复制SELECT "It's a beautiful day"
反之亦然,如果字符串中包含双引号,也可以使用上面三种方式来表示带有双引号的字符串。
至于使用单引号还是双引号表示字符串,我们应该首选单引号,因为这符合 SQL 标准,且是主流做法。
3.反引号
在 MySQL 中,反引号(`)是一种用于转义标识符(例如表名、列名、别名等)的特殊字符。反引号的主要作用是允许你在标识符中使用保留字、特殊字符或包含空格的名称,而不会引发语法错误。
以下是反引号在 MySQL 中的作用与示例:
- 避免与保留关键字冲突。
如果你希望使用一个与 MySQL 中的保留字同名的标识符,可以使用反引号将其括起来,以避免语法错误。
代码语言:javascript复制SELECT `select`, `from`, `where` FROM `my_table`;
- 允许特殊字符。
使用反引号,您可以创建包含特殊字符(如空格、点、逗号等)的标识符。这样,您可以为表、列等对象取名,使其更具描述性,而不受命名规则的限制。
代码语言:javascript复制SELECT `first name`, `last name` FROM `employee.data`;
- 区分大小写。
MySQL 默认情况下对标识符不区分大小写。如果你希望区分,可以使用反引号。
代码语言:javascript复制SELECT `MyColumn` FROM `my_table`;
需要注意的是,反引号在 SQL 标准中并不是通用的,它是 MySQL 特有的语法。大多数其他数据库系统使用双引号或方括号来实现类似的功能。同时,过度使用反引号可能会导致查询变得不够可读,因此建议仅在必要的情况下使用。
4.模式匹配
通配符
SQL 标准中规定模式匹配使用下划线(_)匹配任何单个字符,使用百分号(%)匹配任意数量的字符(包括零个字符)。
在 MySQL 中,SQL 模式默认不区分大小写。使用 SQL 模式时请勿使用 = 或 <>,请改用 LIKE 或 NOT LIKE 比较运算符。
要查找以b开头的名称:
代码语言:javascript复制SELECT * FROM pet WHERE name LIKE 'b%';
-------- -------- --------- ------ ------------ ------------
| name | owner | species | sex | birth | death |
-------- -------- --------- ------ ------------ ------------
| Buffy | Harold | dog | f | 1989-05-13 | NULL |
| Bowser | Diane | dog | m | 1989-08-31 | 1995-07-29 |
-------- -------- --------- ------ ------------ ------------
查找以fy结尾的名称:
代码语言:javascript复制SELECT * FROM pet WHERE name LIKE '%fy';
-------- -------- --------- ------ ------------ -------
| name | owner | species | sex | birth | death |
-------- -------- --------- ------ ------------ -------
| Fluffy | Harold | cat | f | 1993-02-04 | NULL |
| Buffy | Harold | dog | f | 1989-05-13 | NULL |
-------- -------- --------- ------ ------------ -------
查找包含w的名称:
代码语言:javascript复制SELECT * FROM pet WHERE name LIKE '%w%';
---------- ------- --------- ------ ------------ ------------
| name | owner | species | sex | birth | death |
---------- ------- --------- ------ ------------ ------------
| Claws | Gwen | cat | m | 1994-03-17 | NULL |
| Bowser | Diane | dog | m | 1989-08-31 | 1995-07-29 |
| Whistler | Gwen | bird | NULL | 1997-12-09 | NULL |
---------- ------- --------- ------ ------------ ------------
查找恰好包含五个字符的名称,请使用模式字符 _ :
代码语言:javascript复制SELECT * FROM pet WHERE name LIKE '_____';
------- -------- --------- ------ ------------ -------
| name | owner | species | sex | birth | death |
------- -------- --------- ------ ------------ -------
| Claws | Gwen | cat | m | 1994-03-17 | NULL |
| Buffy | Harold | dog | f | 1989-05-13 | NULL |
------- -------- --------- ------ ------------ -------
MySQL 除了提供标准的 SQL 模式匹配,还支持基于扩展正则表达式的模式匹配,类似于 Unix 实用程序(如 vi、grep 和 sed)使用的扩展正则表达式。
如果您想要在 MySQL 中使用正则表达式进行匹配,可以查阅 MySQL 官方文档 Pattern Matching 以了解更多信息。
转义符
由于百分号和下划线是通配符,具有特殊的意义。当我们想要判断字符串中是否包含这两个字符时,例如“50%”,就需要使用一个转义字符将模式中的通配符解释为普通字符。转义字符使用 ESCAPE 指定:
代码语言:javascript复制expr LIKE pat ESCAPE 'escape_char'
默认情况下,MySQL 使用反斜线()作为转义字符。
代码语言:javascript复制SELECT '完成进度 50%' LIKE 'P%%' AS like1, '日期 20150101' LIKE 'P%%' AS like2;
------- -------
| like1 | like2 |
------- -------
| 1 | 1 |
------- -------
上面的查询没有使用转义字符,直接使用“50%”进行匹配,结果“日期 20150101”也满足条件。
代码语言:javascript复制SELECT '完成进度 50%' LIKE 'P%%' AS like1, '日期 20150101' LIKE 'P%%' AS like2;
------- -------
| like1 | like2 |
------- -------
| 1 | 0 |
------- -------
使用转义字符后,50%
只会匹配50%
。
MySQL 可识别下表中所示的转义字符。 对于所有其他转义字符,反斜杠将被忽略。例如,x 仍是 x。 转义字符区分大小写,例如 b 被解释为退格键,而 B 被解释为 B。
Escape Sequence | Character Represented by Sequence |
---|---|