MySQL 中的运算符

一.算数运算符

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

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不会写代码的菜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值