一.算数运算符

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 --> :=,=(赋值)