25.2 MySQL 运算符

2023-10-24_00005

1. 伪表

在MySQL中, DUAL是一个特殊的单行, 单列的虚拟表, 主要用于在SELECT语句中计算表达式或执行函数, 而不需要从实际的数据表中检索数据.
使用DUAL的原因主要有以下几点:* 1. 简化计算: 通过在SELECT语句中使用DUAL, 可以方便地计算表达式或执行函数, 而无需创建临时表或执行子查询.
* 2. 统一语法: 在某些情况下, 使用DUAL可以使SQL语句保持统一的语法结构, 简化代码逻辑.
* 3. 性能优化: 由于DUAL是虚拟表, 不会占用实际的磁盘空间, 也不会对性能产生负面影响.

2. 算术运算

算术运算符主要用于数学运算, 可以连接运算符前后的两个数值或表达式, 对数值或表达式进行运算.
运算符名称作用示例
+加法运算符计算两个值或表达式的和SELECT A + B
-减法运算符计算两个值或表达式的差SELECT A - B
*乘法运算符计算两个值或表达式的乘积SELECT A * B
/ 或 DIV除法运算符计算两个值或表达式的商SELECT A / B 或者 SELECT A DIV B
% 或 MOD求模(求余)运算符计算两个值或表达式的余数SELECT A % B 或者 SELECT A MOD B
注意事项:
* 1. MySQL中对于非整型的表达式进行隐式转换时, 会尝试将其转换为数值类型.如果转换成功, 则使用转换后的数值进行计算; 如果转换失败, MySQL通常会将该表达式按0计算.这种行为是为了确保查询的执行不会因为非数值类型的表达式而中断.隐式转换可能会导致一些意想不到的结果, 尤其是当转换失败时.因此, 在编写MySQL查询时, 最好确保使用的数据类型是匹配的, 以避免潜在的问题.* 2. 以下类型的字符串可以被转为数值:整数字符串: 由数字字符(0-9)组成的字符串, 可以表示一个整数. 例如. "123"可以被转为数值123.浮点数字符串: 由数字字符和小数点组成的字符串, 可以表示一个浮点数(小数). 例如, "3.14"可以被转为数值3.14.科学计数法字符串: 使用科学计数法表示的数值字符串, 例如, "1.23E4"可以被转为数值12300.0.字符串中的空格和其他非数字字符可能会导致转换失败.此外, 某些特殊情况下, 如超出数值类型范围或格式不符合要求, 转换也可能失败.* 3. 在数学运算中, 0不能用作除数; 在MySQL中, 一个数除以0为NULL.
* 4. 与浮点数进程计算得到的结果是浮点数, 除法运算的结果是浮点数(不管是否能除尽, 结果都为一个浮点数).

2.1 加减法运算

-- 加法
mysql> SELECT 1 + 2;
+-------+
| 1 + 2 |
+-------+
|     3 |
+-------+
1 row in set (0.00 sec)
-- 使用伪表统一语法
mysql> SELECT 1 + 2 FROM DUAL;
+-------+
| 1 + 2 |
+-------+
|     3 |
+-------+
1 row in set (0.00 sec)
-- 纯数字字符串(包括整数和浮点数), 可以转换为整型.
mysql> SELECT 1 + '1' FROM DUAL;
+---------+
| 1 + '1' |
+---------+
|       2 |
+---------+
1 row in set (0.00 sec)
-- 不同数据类型相加, 字符串无法转换为数字按0计算.
mysql> SELECT 1 + 'A' FROM DUAL;
+---------+-----------+
| 1 + 'A' | 'A' + 'A' |
+---------+-----------+
|       1 |         0 |
+---------+-----------+
1 row in set, 1 warning (0.00 sec)
-- 减法运算
mysql> SELECT 1 - 1 FROM DUAL;
+-------+
| 1 - 1 |
+-------+
|     0 |
+-------+
1 row in set (0.00 sec)-- 纯数字字符串(包括整数和浮点数), 可以转换为整型.
mysql> SELECT 1 - '1' FROM DUAL;
+---------+
| 1 - '1' |
+---------+
|       0 |
+---------+
1 row in set (0.00 sec)

2.2 乘除法运算

mysql> SELECT 100 * 1, 100 * 1.0, 100 / 1.0, 100 / 2, 100 + 2 * 5 / 2, 100 / 3, 100 FROM DUAL;
+---------+-----------+-----------+---------+-----------------+---------+-----+
| 100 * 1 | 100 * 1.0 | 100 / 1.0 | 100 / 2 | 100 + 2 * 5 / 2 | 100 / 3 | 100 |
+---------+-----------+-----------+---------+-----------------+---------+-----+
|     100 |     100.0 |  100.0000 | 50.0000 |        105.0000 | 33.3333 | 100 |
+---------+-----------+-----------+---------+-----------------+---------+-----+
1 row in set (0.00 sec)

2.3 求模运算

mysql> SELECT 10 % 2, 10 % 3 FROM DUAL;
+--------+--------+
| 10 % 2 | 10 % 3 |
+--------+--------+
|     0  |      1 |
+--------+--------+
1 row in set (0.00 sec)
-- 筛选出员工表中employee_id是偶数的员工名字:
mysql> SELECT first_name FROM employees WHERE employee_id % 2 = 0;
+-------------+
| first_name  |
+-------------+
| Steven      |
| ...         | -- 省略
| Hermann     |
| William     |
+-------------+
54 rows in set (0.03 sec)

3. 比较运算符

比较运算符: 用来对表达式左边的操作数和右边的操作数进行比较, 比较的结果为真则返回1, 比较的结果为假则返回0, 其他情况则返回NULL.
比较运算符经常被用来作为SELECT查询语句的条件来使用, 返回符合条件的结果记录.
运算符名称作用例示
=等于判断两个值, 字符串或表达式是否相等SELECT C FROM TABLE WHERE A= B
<=>安全等于安全地判断两个值, 字符串或表达式是否相等SELECT C FROM TABLE WHERE A<=>B
!= 或 <>不等于判断两个值, 字符串或表达式是否不相等SELECT C FROM TABLE WHERE A!= B
<小于判断前面的值, 字符串或表达式是否小于后面的值, 字符串或表达式SELECT C FROM TABLE WHERE A<B
<=小于等于判断前面的值, 字符串或表达式是否小于等于后面的值, 字符串或表达式SELECT C FROM TABLE WHERE A<= B
>大于判断前面的值, 字符串或表达式是否大于后面的值, 字符串或表达式SELECT C FROM TABLE WHERE A>B
>=大于等于判断前面的值, 字符串或表达式是否大于等于后面的值l, 字符串或表达式SELECT C FROM TABLE WHERE A>= B
注意事项: 
* SQL中赋值符号使用( := ).
* 整型与字符比较时, 会将字符串进行隐式转换, 转换失败则按0计算.
* 字符串之间按ASCII编码的数字进行比较.

3.1 等号

mysql> SELECT 1 = 1, 1 = '1', 0 = 'a', 'a' = 'a', (5 + 3) = (2 + 6), '' = NULL , NULL = NULL;
+-------+---------+---------+-----------+-------------------+-----------+-------------+
| 1 = 1 | 1 = '1' | 0 = 'a' | 'a' = 'a' | (5 + 3) = (2 + 6) | '' = NULL | NULL = NULL |
+-------+---------+---------+-----------+-------------------+-----------+-------------+
|     1 |       1 |       1 |         1 |                 1 |      NULL |        NULL |
+-------+---------+---------+-----------+-------------------+-----------+-------------+
1 row in set, 1 warning (0.00 sec)
-- 查询员工表工资为10000的员工名字:
mysql> SELECT first_name FROM employees WHERE salary = 10000;
+------------+
| first_name |
+------------+
| Peter      |
| Janette    |
| Harrison   |
| Hermann    |
+------------+
4 rows in set (0.00 sec)

3.2 安全等于

安全等于运算符( <=> )可以用来对NULL进行判断.
其中一个操作数为NULL时, 其返回值为0, 而不为NULL.
在两个操作数均为NULL时, 其返回值为1, 而不为NULL;
mysql> SELECT 1 <=> '1', 1 <=> 0, 'a' <=> 'a', (5 + 3) <=> (2 + 6), '' <=> NULL, NULL <=> NULL FROM DUAL;
+-----------+---------+-------------+---------------------+-------------+---------------+
| 1 <=> '1' | 1 <=> 0 | 'a' <=> 'a' | (5 + 3) <=> (2 + 6) | '' <=> NULL | NULL <=> NULL |
+-----------+---------+-------------+---------------------+-------------+---------------+
|         1 |       0 |           1 |                   1 |           0 |             1 |
+-----------+---------+-------------+---------------------+-------------+---------------+
1 row in set (0.00 sec)
-- 查询员工表中佣金百分比为NULL的员工名字和佣金百分比:
mysql> SELECT first_name, commission_pct FROM employees WHERE commission_pct <=> NULL;
+-------------+----------------+
| first_name  | commission_pct |
+-------------+----------------+
| Steven      |           NULL |
| Neena       |           NULL |
| ...         |           ...  | -- 省略
| Hermann     |           NULL |
| Shelley     |           NULL |
| William     |           NULL |
+-------------+----------------+
72 rows in set (0.00 sec)

3.3 不等于

不等于运算符用于判断两边的数字, 字符串或者表达式的值是否不相等, 如果不相等则返回1, 相等则返回0.
mysql> SELECT 1 <> 1, 1 != 2, 'a' != 'b', (3+4) <> (2+6), 'a' != NULL, NULL <> NULL;
+--------+--------+------------+----------------+-------------+--------------+
| 1 <> 1 | 1 != 2 | 'a' != 'b' | (3+4) <> (2+6) | 'a' != NULL | NULL <> NULL |
+--------+--------+------------+----------------+-------------+--------------+
|      0 |      1 |          1 |              1 |        NULL |         NULL |
+--------+--------+------------+----------------+-------------+--------------+
1 row in set (0.00 sec)

3.4 大于小于

-- 查询员工表中工资在6000到8000之间的员工名字, 和薪资, 不包括6000和8000.
mysql> SELECT first_name, salary FROM employees WHERE salary > 6000 AND salary < 8000;
+-------------+---------+
| first_name  | salary  |
+-------------+---------+
| Ismael      | 7700.00 |
| Jose Manuel | 7800.00 |
| ...         | ...     |
| Kimberely   | 7000.00 |
| Charles     | 6200.00 |
| Susan       | 6500.00 |
+-------------+---------+
19 rows in set (0.00 sec)

4. 比较运算关键字

运算符名称描述示例
IS NULL为空运算判断值, 字符串或表达式是否为空SELECT B FROM TABLE WHERE A IS NULL
IS NOT NULL不为空运算判断值, 字符串或表达式是否不为空SELECT B FROM TABLE WHERE A IS NOT NULL
LEAST最小值运算在多个值中返回最小值SELECT D FROM TABLE WHERE C = LEAST(A,B)
GREATEST最大值运算在多个值中返回最大值SELECT D FROM TABLE WHERE C = GREATEST(A,B)
BETWEEN ... AND ...两值之间的运算判断一个值是否在两个值之间SELECT D FROM TABLE WHERE C BETWEEN A AND B
ISNULL为空运算判断一个值, 字符串或表达式是否为空SELECT B FROM TABLE WHERE A ISNULL
IN属于运算判断一个值是否为列表中的任意一个值SELECT D FROM TABLE WHERE C IN (A, B)
NOT IN不属于运算判断一个值是否不是一个列表中的任意一个值SELECT D FROM TABLE WHERE C NOT IN (A,B)
LIKE模糊匹配运算判断一个值是否符合模糊匹配规则SELECT C FROM TABLE WHERE A LIKE B
REGEXP正则表达式运算判断一个值是否符合正则表达式的规则SELECT C FROM TABLE WHERE A REGEXP B
RLIKE正则表达式运算判断一个值是否符合正则表达式的规则(同义词)SELECT C FROM TABLE WHERE A RLIKE B

4.1 为空运算符

IS NULL或者ISNULL判断一个值是否为NULL, 如果为NULL则返回1, 否则返回0.
-- 查询员工表中commission_pct为NULL的员工名字:
mysql> SELECT first_name FROM employees WHERE  commission_pct IS NULL;
+-------------+----------------+
| first_name  | commission_pct |
+-------------+----------------+
| Steven      |           NULL |
| Neena       |           NULL |
| ...         |           ...  | -- 省略
| Hermann     |           NULL |
| Shelley     |           NULL |
| William     |           NULL |
+-------------+----------------+
72 rows in set (0.00 sec)
-- 或者
mysql> SELECT first_name FROM employees WHERE ISNULL(commission_pct);
+-------------+----------------+
| first_name  | commission_pct |
+-------------+----------------+
| Steven      |           NULL |
| Neena       |           NULL |
| ...         |           ...  | -- 省略
| Hermann     |           NULL |
| Shelley     |           NULL |
| William     |           NULL |
+-------------+----------------+
72 rows in set (0.00 sec)

4.2 不为空运算

IS NOT NULL判断一个值是否为NULL, 如果不为NULL则返回1, 否则返回0.
-- 查询员工表中commission_pct为不NULL的员工名字:
mysql> SELECT first_name FROM employees WHERE commission_pct IS NOT NULL;
+-------------+
| first_name  |
+-------------+
| John        |
| ...         | -- 省略
| Kimberely   |
| Charles     |
+-------------+
35 rows in set (0.00 sec)
-- 或 (先判断是否为NULL, 然后取反)
mysql> SELECT first_name FROM employees WHERE NOT commission_pct <=> NULL;
+-------------+
| first_name  |
+-------------+
| John        |
| ...         | -- 省略
| Kimberely   |
| Charles     |
+-------------+

4.3 最小/大运算符

-- 比较序列中最大的值
mysql> SELECT LEAST('g','b','t','m'), GREATEST('g','b','t','m') FROM DUAL;
+------------------------+---------------------------+
| LEAST('g','b','t','m') | GREATEST('g','b','t','m') |
+------------------------+---------------------------+
| b                      | t                         |
+------------------------+---------------------------+
1 row in set (0.01 sec)

4.4 区间取值

区间取值: 查询的字段 BETWEEN 边界下限 AND 边界上限; 包含边界值.
-- 查询员工表中工资在6000到8000的员工名字.
mysql> SELECT first_name FROM employees WHERE salary BETWEEN 6000 AND 8000;
+-------------+
| first_name  |
+-------------+
| Bruce       |
| Ismael      |
| ...         | -- 省略
| Pat         |
| Susan       |
+-------------+
24 rows in set (0.00 sec)

4.5 属于

-- 查询员工表中部门编号为10, 20, 30的员工姓名和部门id:
mysql> SELECT first_name, department_id FROM employees WHERE 
department_id = 10 OR department_id = 20 OR department_id = 30;
+------------+---------------+
| first_name | department_id |
+------------+---------------+
| Jennifer   |            10 |
| Michael    |            20 |
| Pat        |            20 |
| Den        |            30 |
| Alexander  |            30 |
| Shelli     |            30 |
| Sigal      |            30 |
| Guy        |            30 |
| Karen      |            30 |
+------------+---------------+
9 rows in set (0.01 sec)mysql> SELECT first_name, department_id FROM employees WHERE department_id IN (10, 20, 30);
+------------+---------------+
| first_name | department_id |
+------------+---------------+
| Jennifer   |            10 |
| Michael    |            20 |
| Pat        |            20 |
| Den        |            30 |
| Alexander  |            30 |
| Shelli     |            30 |
| Sigal      |            30 |
| Guy        |            30 |
| Karen      |            30 |
+------------+---------------+
9 rows in set (0.00 sec)

4.6 不属于

-- 查询员工表中部门编号不是10, 20, 30的员工姓名和部门id:
mysql>  SELECT first_name, department_id FROM employees WHERE department_id NOT IN (10, 20, 30);
+-------------+---------------+
| first_name  | department_id |
+-------------+---------------+
| Steven      |            90 |
| Neena       |            90 |
| ...         |            .. | -- 省略
| Susan       |            40 |
| Hermann     |            70 |
| Shelley     |           110 |
| William     |           110 |
+-------------+---------------+

4.7 模糊查询

在模糊查询中, 有两个人特殊符号:
* 1. 百分号(%): 代表不确定个数的字符(0, 1个或多个).
* 2. 下划线(_): 代表一个不确定的字符.
* 可以在特殊符号前面添加\取消转义; 还可以使用关键字ESCAPE指定取消转义的字符.
-- 查询员工表中包含字符'a'的员工名字.
mysql> SELECT first_name FROM employees WHERE first_name LIKE '%a%';
+-------------+
| first_name  |
+-------------+
| Neena       |
| Alexander   |
| David       |
| Valli       |
| ...         | -- 省略
| Hermann     |
| William     |
+-------------+
70 rows in set (0.00 sec)
-- 查询员工表中名字以'a'开头的员工名字.
mysql> SELECT first_name FROM employees WHERE first_name LIKE 'a%';
+------------+
| first_name |
+------------+
| Alexander  |
| Alexander  |
| Adam       |
| Alberto    |
| Allan      |
| Amit       |
| Alyssa     |
| Alexis     |
| Anthony    |
| Alana      |
+------------+
10 rows in set (0.00 sec)
-- 查询员工表中名字含有字符'a'与字符'e'的员工名字.
mysql> SELECT first_name FROM employees WHERE first_name LIKE '%a%' AND first_name LIKE '%e%';
+-------------+
| first_name  |
+-------------+
| Neena       |
| Alexander   |
| Daniel      |
| ...         | -- 省略
| Michael     |
| Hermann     |
+-------------+
29 rows in set (0.00 sec)-- 或
mysql> SELECT first_name FROM employees WHERE first_name LIKE '%a%e%' OR first_name LIKE '%e%a%';
+-------------+
| first_name  |
+-------------+
| Neena       |
| Alexander   |
| Daniel      |
| ...         | -- 省略
| Michael     |
| Hermann     |
+-------------+
29 rows in set (0.00 sec)
-- 查询员工表中, 名字的第3个字符是'a'的员工名字:
mysql> SELECT first_name FROM employees WHERE first_name LIKE "__a%";
+------------+
| first_name |
+------------+
| Diana      |
| Adam       |
| Shanta     |
| Clara      |
| Charles    |
| Jean       |
| Alana      |
+------------+
7 rows in set (0.00 sec)
-- 查询职位历史表中(job_history)职位id的第2个字符是_且第3个字符是'A'的职位id:
mysql> SELECT job_id FROM job_history WHERE job_id LIKE '__\_a%';
+------------+
| job_id     |
+------------+
| AC_ACCOUNT |
| AC_ACCOUNT |
| AD_ASST    |
+------------+
3 rows in set (0.00 sec)
-- 使用关键字ESCAPE自定义取消转义符号:
mysql>  SELECT job_id FROM job_history WHERE job_id LIKE '__$_a%' ESCAPE '$';
+------------+
| job_id     |
+------------+
| AC_ACCOUNT |
| AC_ACCOUNT |
| AD_ASST    |
+------------+
3 rows in set (0.00 sec)

4.8 REGEXP运算符

REGEXP运算符用来匹配字符串, 语法格式为: expr REGEXP 匹配条件.
如果expr满足匹配条件, 返回1, 如果不满足, 则返回0.
若expr或匹配条件任意一个为NULL, 则结果为NULL.
REGEXP运算符在进行匹配时, 常用的有下面几种通配符:
* 1. "^": 匹配以该字符后面的字符开头的字符串.
* 2. "$": 匹配以该字符前面的字符结尾的字符串.
* 3. ".": 匹配任何一个单字符.
* 4. "[...]": 匹配在方括号内的任何字符.例如, "[abc]"匹配'a''b''c'.可以使用一个'-'号设置区间范围. "[a-z]"匹配任何字母, "[0-9]"匹配任何数字.
* 5. "*": 匹配零个或多个在它前面的字符.例如, "x*"匹配任何数量的"x"字符, "[0-9]*"匹配任何数量的数字, ".*"匹配任何数量的任何字符, 包括空字符串.
-- 匹配员工表中名字以A开头的员工名字:
mysql> SELECT first_name FROM employees WHERE first_name REGEXP '^a';
+------------+
| first_name |
+------------+
| Alexander  |
| Alexander  |
| ...        |
| Alexis     |
| Anthony    |
| Alana      |
+------------+
10 rows in set (0.02 sec)
-- 匹配员工表中名字以r结尾的员工名字:
mysql> SELECT first_name FROM employees WHERE first_name REGEXP 'r$';
+-------------+
| first_name  |
+-------------+
| Alexander   |
| Alexander   |
| ...         |
| Tayler      |
| Jennifer    |
| Jennifer    |
+-------------+
11 rows in set (0.00 sec)

5. 逻辑运算

逻辑运算:
* 1. 逻辑与 AND (&&): 当两个布尔值同时为true,返回true; 否则, 返回false.
* 2. 逻辑或 OR  (||): 当两个布尔值中至少一个为true, 返回true; 否则, 返回false.
* 3. 逻辑非 NOT (!) : 对单个布尔值进行取反操作, 即将true变为false, false变为true.
* 4. 逻辑异或 XOR   : 当两个布尔值一个为true, 一个为false, 返回true.如果两个布尔值相同, 即都为true或都为false, 异或操作返回false.以下是AND, OR, NOT和XOR四种逻辑运算的真值表格:
ABAND (A && B)OR (A || B)NOT (!A)XOR (A ^ B)
truetruetruetruefalsefalse
truefalsefalsetruefalsetrue
falsetruefalsetruetruetrue
falsefalsefalsefalsetruefalse
-- 查询员工表中, 部门id为10或者20的员工名字和部门id:
mysql> SELECT first_name, department_id FROM employees WHERE department_id = 10 OR department_id = 20;
+------------+---------------+
| first_name | department_id |
+------------+---------------+
| Jennifer   |            10 |
| Michael    |            20 |
| Pat        |            20 |
+------------+---------------+
3 rows in set (0.03 sec)
-- 查询员工表中, 部门id为50 并且工资为50的员工名字, 工资, 部门id:
mysql> SELECT first_name, salary, department_id FROM employees WHERE department_id = 50 AND salary > 6000;
+------------+---------+---------------+
| first_name | salary  | department_id |
+------------+---------+---------------+
| Matthew    | 8000.00 |            50 |
| Adam       | 8200.00 |            50 |
| Payam      | 7900.00 |            50 |
| Shanta     | 6500.00 |            50 |
+------------+---------+---------------+
4 rows in set (0.00 sec)
-- 查询员工表中, 工资不在6000 - 8000 之间的员工名字, 工资:
mysql> SELECT first_name, salary FROM employees WHERE salary NOT BETWEEN 6000 AND 8000;
+------------+----------+
| first_name | salary   |
+------------+----------+
| Steven     | 24000.00 |
| Neena      | 17000.00 |
| Lex        | 17000.00 |
| ...        |      ... | -- 省略
| Jennifer   |  4400.00 |
| Michael    | 13000.00 |
| Hermann    | 10000.00 |
| Shelley    | 12000.00 |
| William    |  8300.00 |
+------------+----------+
83 rows in set (0.00 sec)
-- 查询员工表中, 佣金提成不为NULL的员工名字, 佣金提成:
-- SELECT first_name, commission_pct FROM employees WHERE commission_pct IS NOT NULL;
mysql> SELECT first_name, commission_pct FROM employees WHERE NOT commission_pct <=> NULL;
+-------------+----------------+
| first_name  | commission_pct |
+-------------+----------------+
| John        |           0.40 |
| Karen       |           0.30 |
| Alberto     |           0.30 |
| Gerald      |           0.30 |
| ...         |            ... | -- 省略
| Alyssa      |           0.25 |
| Jonathon    |           0.20 |
| Jack        |           0.20 |
| Kimberely   |           0.15 |
| Charles     |           0.10 |
+-------------+----------------+
35 rows in set (0.00 sec)
-- 异或两种情况:
* 1. 部门id为50,   则工资小于6000.
* 2. 部门id不为50, 则工资大于6000.
mysql> SELECT first_name, department_id, salary FROM employees WHERE department_id = 50 XOR salary > 6000;
+-------------+---------------+----------+
| first_name  | department_id | salary   |
+-------------+---------------+----------+
| Steven      |            90 | 24000.00 |
| ...         |            .. |      ... | -- 省略
| Alana       |            50 |  3100.00 |
| Kevin       |            50 |  3000.00 |
| Donald      |            50 |  2600.00 |
| Douglas     |            50 |  2600.00 |
| Michael     |            20 | 13000.00 |
| Susan       |            40 |  6500.00 |
| Hermann     |            70 | 10000.00 |
| Shelley     |           110 | 12000.00 |
| William     |           110 |  8300.00 |
+-------------+---------------+----------+

5. 位运算

运算符描述示例
&按位与对两个数字的对应位执行与运算.
|按位或对两个数字的对应位执行或运算.
^按位异或对两个数字的对应位执行异或运算.
~按位取反对一个数字的每个位取反.
>>右移将数字的二进制表示向右移动指定位数.
<<左移将数字的二进制表示向左移动指定位数.
mysql> SELECT 12 & 5, 12 | 5, 12 ^ 5 FROM DUAL;
+--------+--------+--------+
| 12 & 5 | 12 | 5 | 12 ^ 5 |
+--------+--------+--------+
|      4 |     13 |      9 |
+--------+--------+--------+
1 row in set (0.00 sec)
十进制: 12 --> 二进制: 1 1 0 0   十进制: 12 --> 二进制: 1 1 0 0   十进制: 12 --> 二进制: 1 1 0 0  
十进制:  5 --> 二进制: 0 1 0 1   十进制:  5 --> 二进制: 0 1 0 1   十进制:  5 --> 二进制: 0 1 0 1
与计算: --一一得一-------------  或计算: --有一得一-------------   异或计算:--一零得一-----------
十进制:  4 <-- 二进制: 0 1 0 0   十进制: 13 <-- 二进制: 1 1 0 1    十进制: 9 <-- 十进制: 1 0 0 1
mysql> SELECT  ~1 FROM DUAL;
+----------------------+
| ~1                   |
+----------------------+
| 18446744073709551614 |
+----------------------+
1 row in set (0.00 sec)mysql> SELECT 10 & ~1 FROM DUAL;
+---------+
| 10 & ~1 |
+---------+
|      10 |
+---------+
1 row in set (0.00 sec)
数字1:  0000000000000000000000000000000000000000000000000000000000000001,
1取反:  1111111111111111111111111111111111111111111111111111111111111110. (18446744073709551614)
数字10: 0000000000000000000000000000000000000000000000000000000000001010,
与运算: ----------------------------------------------------------------
数字10: 0000000000000000000000000000000000000000000000000000000000001010.
-- 在一定范围内满足: 每向左移动1位, 相当于乘以2; 每向右移动一位, 相当于除以2.
mysql> SELECT 4 << 1 , 8 >> 1 FROM DUAL;
+--------+--------+
| 4 << 1 | 8 >> 1 |
+--------+--------+
|      8 |      4 |
+--------+--------+
1 row in set (0.00 sec)

6. 运算符优先级

优先级运算符描述
1:=, =(赋值)赋值操作符.
2OR(||), XOR逻辑或, 逻辑异或.
3AND(&&)逻辑与操作符.
4NOT逻辑非操作符.
5BETWEEN, CASE, WHEN, THEN, ELSEBETWEEN, CASE, WHEN, ELSE操作符.
6= (比较运算符), <=>, >=, >, <=, <, <>, !=, IS, LIKE, REGEXP, IN比较运算符和模式匹配操作符.
7|按位或操作符.
8&按位与操作符.
9<<, >>左位移, 右位移操作符.
10-, +减法, 加法操作符.
11\*, /, DIV, %, MOD乘法, 除法, 整数除法, 取余操作符.
12^按位异或操作符.
13-(负号), ~(按位取反)一元负号, 一元按位取反操作符.
14!逻辑非操作符(部分MySQL版本中支持).
15()括号, 改变运算符的优先级.
请注意, 表格中较高的优先级的运算符会优先进行计算, 而较低优先级的运算符则会在较高优先级运算符计算完毕后进行.
括号可以用于改变运算符的优先级.

7. 正则表达式查询

正则表达式通常被用来检索或替换那些符合某个模式的文本内容, 根据指定的匹配模式匹配文本中符合要求的特殊字符串.
例如: 从一个文本文件中提取电话号码, 查找一篇文章中重复的单词或者替换用户输入的某些敏感词语等,
这些地方都可以使用正则表达式; 正则表达式强大而且灵活,可以应用于非常复杂的查询.
MySQL中使用REGEXP关键字指定正则表达式的字符匹配模式.下表列出了REGEXP操作符中常用字符匹配列表:
选项说明例子示例
^匹配以指定字符开头的字符串.'^b': 匹配以字母 b 开头的字符串.book, big, bababa, bike
$匹配以指定字符结尾的字符串.'st$': 匹配以 st 结尾的字符串.test, resist, persist
.匹配任何单个字符.'b.t': 匹配任何b和t之间有一个字符的字符串.bit, bat, but, bite
*匹配前面的字符0次或更多次.'f*n': 匹配字符 n 前面有任意个字符 f 的字符串.fn, fan, faan, fabcn
+匹配前面的字符至少1次或多次.'ba+': 匹配以b开头后面紧跟至少有一个a的字符串ba, bay, bare, battle
<字符串>匹配包含指定字符串的文本.'fa': 匹配包含fa的字符串fan, afa, faad
[字符集合]匹配字符集合中的任何一个字符.'[xa]': 匹配包含x或者z的字符串.dizzy, zebra, x-ray, extra
[^ ]匹配不在指定字符集合中的任何字符.'[^abc]': 匹配任何不包含a, b, c的字符串.desk, fox, f8ke
字符串{n,}匹配前面的字符串至少n次.'b{n}': 匹配2个或更多的b.bbb, bbbb, bbbbbb
字符串{n,m}匹配前面的字符串至少n次, 至多m次.'b{2, 4}': 匹配含最少2个, 最多4个的b的字符串.bb, bbb, bbbb
如果n为0, 此表达式为可选.a{0,3}: a可以出现0, 1, 2, 3次, 即整个表达式是可选的.无, a, aa, aaa
* 1. 查询以特定字符或字符串开头的记录字符'^'匹配以特定字符或者字符串开头的文本.查询员工表中, 名字以字母'b'开头的员工名字, SQL语句如下:
mysql> SELECT first_name FROM employees WHERE first_name REGEXP '^b';
+------------+
| first_name |
+------------+
| Bruce      |
| Britney    |
+------------+
2 rows in set (0.02 sec)
* 2. 查询以特定字符或字符串结尾的记录字符'$'匹配以特定字符或者字符串结尾的文本.查询员工表中, 名字以字母't'结尾的员工名字, SQL语句如下:
mysql> SELECT first_name FROM employees WHERE first_name REGEXP 't$';
+------------+
| first_name |
+------------+
| Amit       |
| Pat        |
+------------+
2 rows in set (0.00 sec)
* 3. 用符号"."来替代字符串中的任意一个字符, 字符'.'匹配任意一个字符.查询员工表中, 名字中有字母'a''c'且两个字母之间只有一个字母的员工名字, SQL语句如下:
mysql> SELECT first_name FROM employees WHERE first_name REGEXP 'a.c';
+------------+
| first_name |
+------------+
| Nancy      |
| Vance      |
+------------+
2 rows in set (0.00 sec)
* 4. 使用"*""+"来匹配多个字符; 星号'*'匹配前面的字符任意多次, 包括0. 加号'+'匹配前面的字符至少一次.查询员工表中, 名字以字母'b'开头且后面会出现字母'e'的员工名字, SQL语句如下:
mysql> SELECT first_name FROM employees WHERE first_name REGEXP '^b.*e+.*';
+------------+
| first_name |
+------------+
| Bruce      |
| Britney    |
+------------+
2 rows in set (0.00 sec)
* 5. 匹配指定字符串, 正则表达式可以匹配指定字符串, 只要这个字符串在查询文本中即可,如要匹配多个字符串, 多个字符串之间使用分隔符'|'隔开.1. 查询员工表中, 名字中有字符'it'的员工名字; 2. 查询员工表中, 名字中有字符'it''ii'的员工名字;
mysql> SELECT first_name FROM employees WHERE first_name REGEXP 'it';
+------------+
| first_name |
+------------+
| Amit       |
| Sundita    |
| Nandita    |
| Britney    |
+------------+
4 rows in set (0.00 sec)mysql> SELECT first_name FROM employees WHERE first_name REGEXP 'it|ic';
+------------+
| first_name |
+------------+
| Michael    |
| Patrick    |
| Amit       |
| Sundita    |
| Nandita    |
| Britney    |
| Michael    |
+------------+
7 rows in set (0.00 sec)
在一般情况下, LIKE和REGEXP操作符都可以用于匹配指定的字符串.
它们之间的主要区别在于匹配方式和规则的不同.
* 1. LIKE操作符是基于模式匹配的, 使用通配符%和_来匹配任意字符和单个字符.当使用LIKE进行匹配时, 如果要匹配的字符串出现在文本的中间, 它不会被找到并返回相应的行.* 2. REGEXP操作符是基于正则表达式匹配的, 可以执行更复杂和灵活的模式匹配.当使用REGEXP进行匹配时, 如果要匹配的字符串在文本中间出现, 它可以被找到并返回相应的行.
mysql> SELECT first_name FROM employees WHERE first_name LIKE 'it';
Empty set (0.01 sec)mysql> SELECT first_name FROM employees WHERE first_name LIKE '%it%';
+------------+
| first_name |
+------------+
| Amit       |
| Sundita    |
| Nandita    |
| Britney    |
+------------+
4 rows in set (0.00 sec)
* 6. 匹配指定字符中的任意一个, 方括号'[]'指定一个字符集合, 只匹配其中任何一个字符, 即为所查找的文本.查询员工表中, 名字中有字符'a''i'的员工名字;
-- 字符串格式中指定匹配的字符组, 中括号中指定匹配的单个字符.
mysql> SELECT first_name FROM employees WHERE first_name REGEXP '[ai]';
+-------------+
| first_name  |
+-------------+
| Neena       |
| Alexander   |
| David       |
| ...         | --省略
| William     |
+-------------+
88 rows in set (0.00 sec)
* 7. 匹配指定字符以外的字符, "[^字符集合]"匹配不在指定集合中的任何字符.查询员工表中, 名字中不包含字符'a-i'的员工名字;
-- [^]匹配的字符中如果有一个字符不在他的排除范围就能匹配成功!!!
mysql> SELECT first_name FROM employees WHERE first_name REGEXP '[^a-e]';
+-------------+
| first_name  |
+-------------+
| Steven      |
| Neena       |
| Tayler      |
| ...         | --省略
| William     |
+-------------+
107 rows in set (0.00 sec)-- 对于严格排除包含指定字符范围的名字, 可以使用其他方法, 例如使用正则表达式的边界匹配(如^和$).
mysql> SELECT first_name FROM employees WHERE first_name REGEXP '^[^a-e]+$';
+------------+
| first_name |
+------------+
| John       |
| Luis       |
| Guy        |
| TJ         |
| Ki         |
| John       |
| John       |
| Winston    |
| Timothy    |
+------------+
9 rows in set (0.00 sec)-- '^[^a-e]+$': 这个正则表达式表示匹配整个字符串, 该字符串中的每一个字符都不是小写字母'a'到'e'.
-- 这里的+表示前面的字符类([^a-e])可以出现一次或多次.
-- 因此, 这个正则表达式会匹配任何完全由不在'a'到'e'范围内的字符组成的字符串.
* 8. 使用{n,}或者{n,m}来指定字符串连续出现的次数."字符串{n,}"表示至少匹配n次前面的字符; "字符串{n,m}"表示匹配前面的字符串不少于n次, 不多于m次.例如, a{2,}表示字母a连续出现至少2, 也可以大于2; a{2,4}表示字母a连续出现最少2, 最多不能超过4.查询员工表中, 名字中字符'e'出现2-3次的员工名字;
-- 注意: 不要在逗号和数字之间加空格.
mysql> SELECT first_name FROM employees WHERE first_name REGEXP 'e{2, 3}';
ERROR 3692 (HY000): Incorrect description of a {min,max} interval.mysql> SELECT first_name FROM employees WHERE first_name REGEXP 'e{2,3}';
+------------+
| first_name |
+------------+
| Neena      |
+------------+
1 rows in set (0.00 sec)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/170143.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringMVC系列-5 消息转换器

背景 SpringMVC系列的第五篇介绍消息转换器&#xff0c;本文讨论的消息转换指代调用Controller接口后&#xff0c;对结果进行转换处理的过程。 内容包括介绍自定义消息转换器、SpringMVC常见的消息转换器、Spring消息转换器工作原理等三部分。 本文以 SpringMVC系列-2 HTTP请求…

Selenium获取百度百科旅游景点的InfoBox消息盒

前面我讲述过如何通过BeautifulSoup获取维基百科的消息盒&#xff0c;同样可以通过Spider获取网站内容&#xff0c;最近学习了SeleniumPhantomjs后&#xff0c;准备利用它们获取百度百科的旅游景点消息盒&#xff08;InfoBox&#xff09;&#xff0c;这也是毕业设计实体对齐和属…

酷开科技 | 酷开系统沉浸式大屏游戏更解压!

随着家庭娱乐需求日益旺盛&#xff0c;越来越多的家庭消费者和游戏玩家开始追求大屏游戏带来的沉浸感。玩家在玩游戏的时候用大屏能获得更广阔的视野和更出色的视觉包围感&#xff0c;因此用大屏玩游戏已经成为了一种潮流。用酷开系统玩大屏游戏&#xff0c;过瘾又刺激&#xf…

【在英伟达nvidia的jetson-orin-nx和PC电脑ubuntu20.04上-装配ESP32开发调试环境-基础测试】

【在英伟达nvidia的jetson-orin-nx和PC电脑ubuntu20.04上-装配ESP32开发调试环境-基础测试】 1、概述2、实验环境3、 物品说明4、参考资料与自我总结5、实验过程1、创建目录2、克隆下载文件3、 拉取子目录安装和交叉编译工具链等其他工具4、添加环境变量6、将样例文件拷贝到桌面…

计算机网络——理论知识总结(下)

接上条&#xff1a; 计算机网络——理论知识总结&#xff08;上&#xff09; 四.网络层 1.功能&#xff1a;向上提供简单灵活的、无连接的、尽最大努力交付的数据报服务——所传送的分组可能出错、丢失、重复、失序或者超时&#xff0c;这就使得网络中的路由器比较简单&#…

[support2022@cock.li].faust、[tsai.shen@mailfence.com].faust勒索病毒数据怎么处理|数据解密恢复

引言&#xff1a; 威胁网络安全的恶意软件不断涌现&#xff0c;而[support2022cock.li].faust勒索病毒则是其中的一员。这个网络黑暗角落的新星&#xff0c;以其数据绑架的方式&#xff0c;一度成为数据安全的威胁焦点。本文将探究[support2022cock.li].faust勒索病毒的运作方…

Python自动处理pptx:新建、另存、添加幻灯片、添加标题、插入文本图片图形、提取文本

Python-pptx库是一个用于创建、更新和读取Microsoft PowerPoint .pptx 文件的Python库。它允许我们使用Python脚本自动化PowerPoint文件的创建、更新和读取操作&#xff0c;是一个非常方便自动化处理PPTX的工具。 安装 pip install python-pptx创建 from pptx import Prese…

常用linux命令 linux_cmd_sheet

查看文件大小 ls -al 显示每个文件的kb大小 查看系统日志 dmesg -T | tail 在 top 命令中&#xff0c;RES 和 VIRT&#xff08;或者 total-vm&#xff09;是用来表示进程内存使用的两个不同指标&#xff0c;它们之间有以下区别&#xff1a; RES&#xff08;Resident Set Size…

FoneDog iOS Unlocker(ios解锁工具) 适用macos电脑

FoneDog iOS Unlocker是一款专业的iOS设备解锁工具&#xff0c;旨在帮助用户解决iOS设备上的解锁问题。该软件支持解锁各种锁定类型&#xff0c;如数字密码锁、手势密码锁、Touch ID和Face ID等&#xff0c;可以解除iPhone、iPad和iPod Touch等设备的锁定状态。FoneDog iOS Unl…

react项目实现文件预览,比如PDF、txt、word、Excel、ppt等常见文件(腾讯云cos)

使用腾讯云文档预览&#xff0c;需要开通文档预览功能&#xff0c;该功能需要收费的。 使用限制 如果需要图片预览、视频或音频可以使用获取下载链接。 页面代码 <button onClick() > {handleClick(myself/文档.xlsx)}>预览</button><div style{{ height:…

C语言文件操作(详解)

&#x1f493;博客主页&#xff1a;江池俊的博客⏩收录专栏&#xff1a;C语言进阶之路&#x1f449;专栏推荐&#xff1a;✅C语言初阶之路 ✅数据结构探索✅C语言刷题专栏&#x1f4bb;代码仓库&#xff1a;江池俊的代码仓库&#x1f389;欢迎大家点赞&#x1f44d;评论&#x…

c++编译使用log4cplus

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、log4cplus是什么&#xff1f;二、使用步骤1.下载源代码2.开始配置1.配置介绍2.开始编译 3.cmake引用4.示例 总结 前言 C很强大&#xff0c;但是仍然有很多…

AIR101 LuatOS LVGL 显示多个标签例程

屏幕资料 AIR101与屏幕连接 PC端仿真环境合宙官方PC端版本环境搭建教程 PC电脑仿真 -- sys库是标配 _G.sys require("sys") sys.taskInit(function()local cnt0lvgl.init(480,320)--lvgl初始化local cont lvgl.cont_create(nil, nil);-- lvgl.cont_set_fit(cont, …

mac安装jdk

1、下载jdk&#xff08;我的电脑要下载arm版&#xff0c;截图不对&#xff09; Java Downloads | Oraclehttps://www.oracle.com/java/technologies/downloads/#jdk17-mac 2、双击安装

docker部署prometheus+grafana服务器监控(二) - 安装数据收集器 node-exporter

在目标服务器安装数据收集器 node-exporter 1. 安装数据收集器 node-exporter wget https://github.com/prometheus/node_exporter/releases/download/v1.6.1/node_exporter-1.6.1.linux-amd64.tar.gztar xvf node_exporter-1.6.1.linux-amd64.tar.gzmv node_exporter-1.6.1…

使用vue3 搭建一个H5手机端访问的项目

首先说明&#xff0c;我本地之前运行过vue的项目&#xff0c;所以具有一些基础的运行环境&#xff0c;这里直接按步骤讲我项目框架搭建的过程。 这个不建议使用驼峰&#xff0c;按规范单词中间加横杠就可以。一般会出现选择项&#xff0c;按方向键选择&#xff0c;我这边选择了…

Linux音频-基本概念

文章目录 机器声音的采集原理机器声音的播放原理音频相关基本概念计算机采集音频的模型Linux系统音频框架Linux音频框架的三类角色 Linux音频框架参考文章&#xff1a;Linux音频框架 机器声音的采集原理 声音是一种连续的信号&#xff0c;故其是一种模拟量。 录音设备可以捕获…

chatGPT结构及商业级相似模型应用调研

GPT前言 说明 ChatGPT这项技术的历史可以追溯到2018年&#xff0c;当时由Facebook实验室的团队开发出该技术&#xff0c;以开发聊天机器人为目的。随后&#xff0c;ChatGPT在2019年由来自谷歌的DeepMind团队在国际会议ICLR上发表了论文&#xff0c;其中提出了ChatGPT的技术框架…

京东数据分析:2023年9月京东白酒行业品牌销售排行榜

鲸参谋监测的京东平台9月份白酒市场销售数据已出炉&#xff01; 9月白酒市场的整体热度较高&#xff0c;贵州茅台先是与瑞幸联名推出酱香拿铁&#xff0c;后又宣布与德芙推出联名产品酒心巧克力&#xff0c;引起了诸多消费者的关注。在这一热度的加持下&#xff0c;从销售上看&…

前端时间分片渲染

在经典的面试题中&#xff1a;”如果后端返回了十万条数据要你插入到页面中&#xff0c;你会怎么处理&#xff1f;” 除了像 useVirtualList 这样的虚拟列表来处理外&#xff0c;我们还可以通过 时间分片 来处理 通过 setTimeout 直接上一个例子&#xff1a; <!--* Autho…