第04章 运算符
1.算术运算符
算术运算符主要用于数学运算,其可以连接运算符前后的两个数值或表达式,对数值或表达式进行加(+)、减(-)、乘(*)、除(/)和取模(%)运算。
1.1加法与减法运算符
SELECT 100, 100 + 0, 100 - 0, 100 + 50, 100 + 50 -30, 100 + 35.5, 100 - 35.5
FROM dual;
#输出:
+-----+---------+---------+----------+--------------+------------+------------+
| 100 | 100 + 0 | 100 - 0 | 100 + 50 | 100 + 50 -30 | 100 + 35.5 | 100 - 35.5 |
+-----+---------+---------+----------+--------------+------------+------------+
| 100 | 100 | 100 | 150 | 120 | 135.5 | 64.5 |
+-----+---------+---------+----------+--------------+------------+------------+
1 row in set (0.00 sec)
#在SQL中,+没有连接的作用就表示加法运算。此时会将字符串转换为数值(隐式转换)
SELECT 100+'1'
FROM DUAL;
#输出
+---------+
| 100+'1' |
+---------+
| 101 |
+---------+
1 row in set (0.00 sec)
#此时将'a'看作0处理
SELECT 100+'a'
FROM DUAL;
#输出
+---------+
| 100+'a' |
+---------+
| 100 |
+---------+
1 row in set, 1 warning (0.00 sec)
#null值参与运算,结果为null
SELECT 100+NULL
FROM DUAL;
#输出
+----------+
| 100+NULL |
+----------+
| NULL |
+----------+
1 row in set (0.00 sec)
结论:
- 一个整数类型的值对整数进行加法和减法操作,结果还是一个整数;
- 一个整数类型的值对浮点数进行加法和减法操作,结果是一个浮点数;
- 加法和减法的优先级相同,进行先加后减操作与进行先减后加操作的结果是一样的;
- 在Java中,+的左右两边如果有字符串,那么表示字符串的拼接。但是在MySQL中+只表示数值相加。如果遇到非数值类型,先尝试转成数值,如果转失败,就按0计算。(补充:MySQL中字符串拼接要使用字符串函数CONCAT()实现)
1.2乘法与除法运算符
#默认除法除不尽
SELECT 100, 100 * 1, 100 * 1.0, 100 / 1.0, 100 / 2,100 + 2 * 5 / 2,100 /3, 100 DIV 0
FROM DUAL;
#输出
+-----+---------+-----------+-----------+---------+-----------------+---------+-----------+
| 100 | 100 * 1 | 100 * 1.0 | 100 / 1.0 | 100 / 2 | 100 + 2 * 5 / 2 | 100 /3 | 100 DIV 0 |
+-----+---------+-----------+-----------+---------+-----------------+---------+-----------+
| 100 | 100 | 100.0 | 100.0000 | 50.0000 | 105.0000 | 33.3333 | NULL |
+-----+---------+-----------+-----------+---------+-----------------+---------+-----------+
1 row in set (0.00 sec)
结论:
- 一个数乘以浮点数1和除以浮点数1后变成浮点数,数值与原数相等;
- 一个数除以整数后,不管是否能除尽,结果都为一个浮点数;
- 一个数除以另一个数,除不尽时,结果为一个浮点数,并保留到小数点后4位;
- 乘法和除法的优先级相同,进行先乘后除操作与先除后乘操作,得出的结果相同。
- 在数学运算中,0不能用作除数,在MySQL中,一个数除以0为NULL。
1.3求模(求余)运算符
SELECT 12 % 3, 12%5, 12 MOD -5 ,-12 MOD 5 ,-12 MOD -5
FROM DUAL;
+--------+------+-----------+-----------+------------+
| 12 % 3 | 12%5 | 12 MOD -5 | -12 MOD 5 | -12 MOD -5 |
+--------+------+-----------+-----------+------------+
| 0 | 2 | 2 | -2 | -2 |
+--------+------+-----------+-----------+------------+
1 row in set (0.00 sec)
举例演示:筛选出employee_id是偶数的员工
2.比较运算符
- 比较运算符用来对表达式左边的操作数和右边的操作数进行比较,比较的结果为真则返回1,比较的结果为假则返回0,其他情况则返回NULL。
- 比较运算符经常被用来作为SELECT查询语句的条件来使用,返回符合条件的结果记录。
2.1等号运算符
SELECT 1=2, 1!=2, 1='1', 1='a', 0='a'
FROM DUAL;
#输出
+-----+------+-------+-------+-------+
| 1=2 |