一.算数运算符
1.加减运算符
SELECT 100+'1'
FROM DUAL;
#在java语言中,结果为:1001,在SQL中,+没有连接的作用,就表示加法.此时会将字符串转换为字符(隐式转换).
SELECT 100+'a'
#此时将'a'看做0处理
SELECT 100+null
#NULL值参与运算,结果均为NULL
- 拼接使用字符串CONCAT()实现
2.乘除运算符
SELECT 100/2
FROM DUAL; #此时结果为50.0000,因为多数时间,SQL语句中数值除不尽
SELECT 100/0
FROM DUAL; #分母为0,结果为NULL
3.取模运算符
SELECT 12%3,12 MOD -5,-12 % -5
#取模结果的符号只与被取模数相同
二.比较运算符
- 比较运算符用来对表达式左边的操作数和右边的比较,比较的结果为真则返回1;比较的结果为假,则返回0;其他情况返回NULL
- 比较运算法经常被用来作为SELECT查询语句的条件来使用,返回符合条件的结果记录
1.等号运算符
- 等号运算符(=)用于判断等号两边的值,字符串或表达式是否相等,如果相等则返回1,不相等二组返回0
- 使用时,遵循如下规则:
- 如果等号两边的值,字符串或表达式都为字符串,则MySQL会按照字符串进行比较,其比较的是每个字符串中字符的ANSL编码是否相等
- 如果等号两边的值都是整数,则MYSQL会按照整数来比较
- 如果等号两边有一个为整数,另一个为字符串,则将字符串转换为整数进行比较
- 此处存在隐式转化,如果不成功,则看做0来处理
- 如果等号两边的字符串,值,或者表达式中有一个为NULL,则结果为NULL
2.安全等于运算符
- 安全等于运算符(<=>)与等于运算符(=)作用相似,两者唯一的区别为安全等于运算符(<=>)可以用来对空值NULL进行判断,在两操作数均为NULL时返回1,而不为NULL;当有一个 操作数为NULL时,其返回值为0,而不为NULL.
- 只有当两操作数相同时,返回结果与(=)不同,其他都相同
3.不等于运算符
- 不等于运算符(<>和 !=)用于判断两数值,字符串,或者表达式是否相等,不相等返回1,相等返回0
- 不能判断NULL,只要有一个为NULL,结果均为NULL
- IS NULL
#用来判断是否为空,为空结果为1,不为空结果为0
SELECT last_name,salary FROM employees WHERE ISNULL(last_name); 或 WHERE last_name IS NULL
- LEAST GREATEST
#用来判断最大最小数值,字符串或表达式
SELECT LEAST '3','6','7'
FROM DUAL;
- BETWEEN AND
#用来筛选数值在指定范围的字段,此筛选包含边界
SELECT salary
FROM employees
WHERE salary BETWEEN 6000 AND 8000;
- IN
#筛选符合条件的数据
SELECT last_name,salary,department_id
FROM employees
WHERE department_id = 10 OR department_id = 20;
或
WHERE department_id IN (10,20);
- LIKE: 模糊查询
#查询包含'a'的员工信息
SELECT last_name
FROM employees
WHERE last_name LIKE '%a%'; # % :代表不确定个数的字符
#查询以'a'开头的员工信息
SELECT last_name
FROM employees
WHERE last_name LIKE 'a%';
#查询第三个字符为'a'的员工信息
SELECT last_name
FROM employees
WHERE last_name LIKE '__a%'; # _ :代表一个不确定的字符
#查询第二个字符为_且第三个字符为'a'的员工信息
SELECT last_name
FROM employees
WHERE last_name LIKE '_\_a%'; # \ :转义字符
或
WHERE last_name LIKE '_$_a%' ESCAPE '$';
- REGEXP运算符
- 用来匹配字符,语法格式为: expr REGEXP 匹配条件
- 如果expr满足匹配条件,则返回1;如果expr不满足匹配条件,则返回0
- 如果expr或匹配条件中有任意一个为NULL,则结果为NULL
常用通配符 - '^' 匹配以该字符后面的字符开头的字符串
- '.' 匹配任意一个单字符
- "[...]" 匹配在方括号内的任意字符
- '*' 匹配零个或多个在它前面的字符
SELECT 'shaline' REGEXP '^s'
FROM DUAL;
三.逻辑运算符
- 逻辑运算符主要用来判断表达式的真假,在MySQL中,逻辑运算符的返回结果为1,0或NULL
1.逻辑非
- 逻辑非运算符(NOT 或 !)表示当给定的值为0时,返回1;当给定的值为1时,返回0
SELECT last_name
FROM employees
WHERE job_id NOT IN;
- OR 可和 AND一起使用,但要注意两者的优先级,由于AND的优先级高于OR,因此使用时首先操作AND
2.逻辑异或运算符
- 逻辑异或运算符(XOR)表示当给定的值中任意一个为NULL,返回NULL;
- 当给定的两个值都为0或者都不等于0时,返回0;
- 当给定的两个值一个为0,一个不为0时,返回1
SELECT last_name
FROM employees
WHERE department_id IN (10,20) XOR salary > 800;
四.位运算符
- 位运算符是在二进制数上进行计算的运算符
- 位运算符会先将操作数变成二进制数,然后进行位运算
- 最后将计算结果从二进制变回十进制
1.按位与运算符
- 按位与运算符(&)将给定的数值对应的二进制数逐位进行逻辑与运算
- 当给定的数值对应的二进制数值都为1时,返回1;否则,返回0
SELECCT 12&5
FROM DUAL;
因为12的二进制数为1100,5的二进制数为0101,因此结果为4(0100)
2.按位或运算符
- 按位或运算符(|)将给定的数值所对应的二进制数逐位进行逻辑或运算
- 当给定的数值对应的二进制数值有一个或两个为1时,返回1;否则,返回0
SELECCT 12|5
FROM DUAL;
因为12的二进制数为1100,5的二进制数为0101,因此结果为13(1101)
3.按位异或运算符
- 按位异或运算符(^)将给定的数值对应的二进制数逐位进行逻辑异或运算
- 当给定的数值对应的二进制数不同时,返回1;否则,返回0
SELECCT 12^5
FROM DUAL;
因为12的二进制数为1100,5的二进制数为0101,因此结果为9(1001)
4.按位取反运算符
- 按位取反运算符将给定的数值对应的二进制数值逐位进行取反操作,即将1变为0;将0变为1
SELECT 10 & ~1;
FROM DUAL;
- 注意:
此处由于取反运算符(~)的优先级高于按位与运算符(&)的优先级,所以在进行 10 & ~ 1时,首先对1进行按位取反,结果除了最低位为0,其他位都为1;然后与10按位与操作,结果为10
5.移位运算符
- 移位运算符包含 >> ,<<
- 其作用为在一定范围内: 每向左移动一位,结果相当于乘以2
每向右移动一位,结果相当于除以2
SELECT 4 << 1 ,8 >> 1
FROM DUAL;
其结果为 8 , 4
五.运算符的优先级
- 运算符的优先级越高,先进性运算
- SQL语言中的运算符与我们平常使用的运算符等级相同,使用时遵循内心的想法使用即可
- 运算符等级由低向高排列
() --> ! --> -(负号)和~(按位取反) --> ^ --> *,/,DIV,%和MOD --> +和- --> <<与>> --> & --> | --> =(比较),<=>,>=,<,<=,>,<>,!=,IS,LIKE,REGEXP和IN --> BETWEEN,LASE,WHERE ,THEN和ELSE --> NOT --> &&,AND --> ||,OR,XOR --> :=,=(赋值)