MYSQL 运算符总结


Posted in MySQL onNovember 11, 2021

1、算数运算符

MySQL支持的算术运算符:

 

运算符 
作用 
+
加法 
减法
*
乘法 
/,DIV 
除法,返回商
%,MOD 
除法,返回余数

例1: +,-,*,/,%,

mysql> select 0.1+0.333,0.1-0.333,0.1*0.333,1/2,1%2;
+-----------+-----------+-----------+--------+------+
| 0.1+0.333 | 0.1-0.333 | 0.1*0.333 | 1/2    | 1%2  |
+-----------+-----------+-----------+--------+------+
|     0.433 |    -0.233 |    0.0333 | 0.5000 |    1 |
+-----------+-----------+-----------+--------+------+
1 row in set (0.05 sec)

例2:除法运算中,如果除数为0将是返回NULL

mysql> select 1/0;
+------+
| 1/0  |
+------+
| NULL |
+------+
1 row in set (0.00 sec)

例3:模运算的另外一种形式MOD(a,b) 和a%b相同

mysql> select 1%2,mod(1,2);
+------+----------+
| 1%2  | mod(1,2) |
+------+----------+
|    1 |        1 |
+------+----------+
1 row in set (0.00 sec)

2、比较运算符

MySQL支持的比较运算符:

运算符 
作用
=
等于
<>或!= 
不等于
<=>
NULL 安全的等于(NULL-safe)
<
小于 
<= 
小于等于
>
大于 
>= 
大于等于 
BETWEEN
存在与指定范围 
IN
存在于指定集合
IS NULL
为 NULL
IS NOT NULL 
不为 NULL 
LIKE 
通配符匹配 
REGEXP 或 RLIKE 
正则表达式匹配

例1:<>” 和 “=” 相反,如果两则操作不等 返回结果为1,否则返回结果0,“NULL”不能用于“<>”比较

mysql> select 1<>0,1<>1,null<>null;
+------+------+------------+
| 1<>0 | 1<>1 | null<>null |
+------+------+------------+
|    1 |    0 |       NULL |
+------+------+------------+
1 row in set (0.00 sec)

例2:<=>”安全等于运算符和“=”操作相同返回1,区别在于“<=>”在值为null的时候也可以做比较

mysql> select 1<=>1,1<=>0,null<=>null;
+-------+-------+-------------+
| 1<=>1 | 1<=>0 | null<=>null |
+-------+-------+-------------+
|     1 |     0 |           1 |
+-------+-------+-------------+
1 row in set (0.02 sec)

例3:<”当左侧小于右侧时,返回1

mysql> select 'a'<'b','A'<'b','bdf'<'c',1<2;
+---------+---------+-----------+-----+
| 'a'<'b' | 'A'<'b' | 'bdf'<'c' | 1<2 |
+---------+---------+-----------+-----+
|       1 |       1 |         1 |   1 |
+---------+---------+-----------+-----+
1 row in set (0.02 sec)

例4:between,格式为“a BETWEEN min AND max”,表示a大于等于min并且小于等于max的时候,返回1,否则返回0

mysql> select 10 between 10 and 20,9 between 10 and 20;
+----------------------+---------------------+
| 10 between 10 and 20 | 9 between 10 and 20 |
+----------------------+---------------------+
|                    1 |                   0 |
+----------------------+---------------------+
1 row in set (0.01 sec)

例5:regexp,格式为“str REGEXP str_pat”,表示str字符串中含有str_pat相匹配的字符串时,则返回1,否则返回0

mysql> select 'abcdeef' regexp 'ab','abcdef' regexp 'g','abcedf' regexp 'df';
+-----------------------+---------------------+----------------------+
| 'abcdeef' regexp 'ab' | 'abcdef' regexp 'g' | 'abcedf' regexp 'df' |
+-----------------------+---------------------+----------------------+
|                     1 |                   0 |                    1 |
+-----------------------+---------------------+----------------------+
1 row in set (0.01 sec)

其他的使用简单,直接上语法,示例就不写了

  • in,使用格式为“a IN (value1,value2,…)
  • IS NULL,使用格式为“a IS NULL
  • IS NOT NULL,使用格式为“a IS NOT NULL
  • LIKE,使用格式为“a LIKE %123%

3、逻辑运算符

MySQL中的逻辑运算符:

运算符
作用 
NOT 或!
逻辑非 
AND 或&& 
逻辑与 
OR 或 ||
逻辑或 
XOR
逻辑异或 

例1: ““NOT”或“”表示逻辑非。返回和操作数相反的结果。当操作为0,则返回1;当操作为1,则返回0,但是NOT NLLL返回null

mysql> select not 0,!0,not 1,not null;
+-------+----+-------+----------+
| not 0 | !0 | not 1 | not null |
+-------+----+-------+----------+
|     1 |  1 |     0 |     NULL |
+-------+----+-------+----------+
1 row in set (0.00 sec)

例2: AND”和“&&”表示逻辑与运算,当操作数均为非零值,返回结果1,否则返回0,当操作数中有任意一个为NULL,其中一个值如果为0,返回0;其他值都是>0的数值,另外有NULL,则返回NULL

mysql> select (1 and 1),(0 and 1),(3 and 1),(0 and null),(1 and null);
+-----------+-----------+-----------+--------------+--------------+
| (1 and 1) | (0 and 1) | (3 and 1) | (0 and null) | (1 and null) |
+-----------+-----------+-----------+--------------+--------------+
|         1 |         0 |         1 |            0 |         NULL |
+-----------+-----------+-----------+--------------+--------------+
1 row in set (0.00 sec)
mysql> select 1 and NULL and 0;
+------------------+
| 1 and NULL and 0 |
+------------------+
|                0 |
+------------------+
1 row in set (0.00 sec)

mysql> select 1 and NULL and 3;
+------------------+
| 1 and NULL and 3 |
+------------------+
|             NULL |
+------------------+
1 row in set (0.00 sec)

例3:OR”或“||”表示逻辑或运算。当操作数均不为NULL时,任意一方非零,则结果为1,否则为0;当有一个操作数为NULL,如果另一个操作数非零,则结果为1,否则结果为NULL

mysql> select (1 or 0),(0 or 0),(1 or NULL),(0 or NULL),(NULL or NULL);
+----------+----------+-------------+-------------+----------------+
| (1 or 0) | (0 or 0) | (1 or NULL) | (0 or NULL) | (NULL or NULL) |
+----------+----------+-------------+-------------+----------------+
|        1 |        0 |           1 |        NULL |           NULL |
+----------+----------+-------------+-------------+----------------+
1 row in set (0.00 sec)

例4:XOR表示逻辑异或。当任意一个操作数为 NULL 时,返回值为 NULL。对于非 NULL 的操作数,如果两个的逻辑真假值相异,则返回结果 1;否则返回 0。

mysql> select (0 xor 0),(1 xor 0),(1 xor 1),(1 xor null),(0 xor null),(null xor null);
+-----------+-----------+-----------+--------------+--------------+-----------------+
| (0 xor 0) | (1 xor 0) | (1 xor 1) | (1 xor null) | (0 xor null) | (null xor null) |
+-----------+-----------+-----------+--------------+--------------+-----------------+
|         0 |         1 |         0 |         NULL |         NULL |            NULL |
+-----------+-----------+-----------+--------------+--------------+-----------------+
1 row in set (0.00 sec)

4、位运算符

MySQL支持的位运算符:

运算符 
作用
&
位与(位 AND) 
|
位或 (位 OR ) 
^
位异或(位 XOR)
位取反
>>
位右移
<<
位左移 

例1: “位与”对多个操作数的二进制位作逻辑与操作。2&3,2的二进制数为10,3的二进制数为11,将此做与操作,结果还是10,转换为十进制结果就是2

mysql> select 2&3;
+-----+
| 2&3 |
+-----+
|   2 |
+-----+
1 row in set (0.01 sec)

例2: “位或”对多个操作数的二进制位作逻辑或操作。2&3,2的二进制数为10,3的二进制数为11,将此做与操作,结果就变成11,转换为十进制结果就是3

mysql> select 2|3;
+-----+
| 2|3 |
+-----+
|   3 |
+-----+
1 row in set (0.00 sec)

例3:位异或”对多个操作数的二进制位作异或操作。2^3 ,2的二进制数为10,3的二进制数为11,10^11结果就是01,转换为十进制结果就是1

mysql> select 2^3;
+-----+
| 2^3 |
+-----+
|   1 |
+-----+
1 row in set (0.01 sec)

例4: “位取反”对操作数的二进制位做NOT操作,这里的操作数只能是一位,解释:在mysql中常亮数字默认会以8字节表示,8个字节就是64位,而常量1的二进制 就是前面63个0,1个1,位去反后就是63个1,1个0,转换为二进制后就是 18446744073709551614,

mysql> select ~1,~18446744073709551614
    -> ;
+----------------------+-----------------------+
| ~1                   | ~18446744073709551614 |
+----------------------+-----------------------+
| 18446744073709551614 |                     1 |
+----------------------+-----------------------+
1 row in set (0.01 sec)
mysql> select bin(18446744073709551614);
+------------------------------------------------------------------+
| bin(18446744073709551614)                                        |
+------------------------------------------------------------------+
| 1111111111111111111111111111111111111111111111111111111111111110 |
+------------------------------------------------------------------+
1 row in set (0.03 sec)

例5: “位右移”对左操作数向右移动操作数指定的位数。例如100>>3,对100的二进制数0001100100右移动3位,0000001100,转换为二进制数就是12:

mysql> select 100>>3;
+--------+
| 100>>3 |
+--------+
|     12 |
+--------+
1 row in set (0.00 sec)

例6: “位左移”对左操作数向左移动操作数指定的位数。例如100<<3,对100的二进制数0001100100000右移动3位,1100100000000,转换为二进制数就是800:

mysql> select 100<<3;
+--------+
| 100<<3 |
+--------+
|    800 |
+--------+
1 row in set (0.00 sec)

5、运算符的优先级

MySQL中的运算符优先级:

优先级顺序
运算符
1
:= 
2
||, OR, XOR
3
&&, AND 
4
NOT 
5
BETWEEN, CASE, WHEN, THEN, ELSE 
6
=, <=>, >=, >, <=, <, <>, !=, IS, LIKE, REGEXP, IN
7
8
&
9
<<, >>
10
-, +
11
*, /, DIV, %, MOD 
12
13
- (一元减号), ~ (一元比特反转) 
14

到此这篇关于MYSQL 运算符总结的文章就介绍到这了,更多相关MYSQL 运算符内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
Mysql基础之常见函数
Apr 22 MySQL
解决MySQL存储时间出现不一致的问题
Apr 28 MySQL
MySQL 覆盖索引的优点
May 19 MySQL
MySQL索引失效的典型案例
Jun 05 MySQL
MySQL 亿级数据导入导出及迁移笔记
Jun 18 MySQL
SQL实现LeetCode(196.删除重复邮箱)
Aug 07 MySQL
深入解析MySQL索引数据结构
Oct 16 MySQL
MySQL8.0升级的踩坑历险记
Nov 01 MySQL
浅谈如何保证Mysql主从一致
Mar 13 MySQL
MySQL数据库事务的四大特性
Apr 20 MySQL
MySQL中JOIN连接的基本用法实例
Jun 05 MySQL
MySQL串行化隔离级别(间隙锁实现)
Jun 16 MySQL
MySQL 数据类型详情
Nov 11 #MySQL
MYSQL 表的全面总结
Nov 11 #MySQL
MySQL 服务和数据库管理
面试被问select......for update会锁表还是锁行
mysql的数据压缩性能对比详情
Nov 07 #MySQL
Mysql数据库手动及定时备份步骤
一篇文章看懂MySQL主从复制与读写分离
You might like
用libTemplate实现静态网页的生成
2006/10/09 PHP
PHP中大于2038年时间戳的问题处理方案
2015/03/03 PHP
laravel-admin解决表单select联动时,编辑默认没选上的问题
2019/09/30 PHP
PHP中-&gt;和=&gt;的含义及使用示例解析
2020/08/06 PHP
php实现简易计算器
2020/08/28 PHP
Aster vs Newbee BO5 第二场2.19
2021/03/10 DOTA
javascript xml为数据源的下拉框控件
2009/07/07 Javascript
学习ExtJS table布局
2009/10/08 Javascript
js面向对象 多种创建对象方法小结
2012/05/21 Javascript
微信小程序 window_x64环境搭建
2016/09/30 Javascript
JS简单实现点击按钮或文字显示遮罩层的方法
2017/04/27 Javascript
JS实现点击循环切换显示内容的方法
2017/10/19 Javascript
vue 设置路由的登录权限的方法
2018/07/03 Javascript
JS监听滚动和id自动定位滚动
2018/12/18 Javascript
微信小程序拍照和摄像功能实现方法示例
2019/02/01 Javascript
Vue在chrome44偶现点击子元素事件无法冒泡的解决方法
2019/12/15 Javascript
vue3+typescript实现图片懒加载插件
2020/10/26 Javascript
vue 在服务器端直接修改请求的接口地址
2020/12/19 Vue.js
原生js拖拽功能制作滑动条实例代码
2021/02/05 Javascript
python使用urllib模块开发的多线程豆瓣小站mp3下载器
2014/01/16 Python
轻松实现python搭建微信公众平台
2016/02/16 Python
Python单向链表和双向链表原理与用法实例详解
2018/08/31 Python
python对视频画框标记后保存的方法
2018/12/07 Python
python 提取文件指定列的方法示例
2019/08/07 Python
Python argparse模块应用实例解析
2019/11/15 Python
Python 爬虫的原理
2020/07/30 Python
css3 实现滚动条美化效果的实例代码
2021/01/06 HTML / CSS
SQL面试题
2013/04/30 面试题
工程地质勘察专业大学生求职信
2013/10/13 职场文书
中学生在校期间的自我评价分享
2013/11/13 职场文书
毕业生的自我评价
2013/12/30 职场文书
打架检讨书100字
2014/01/08 职场文书
创建文明学校实施方案
2014/03/11 职场文书
初中英语课后反思
2014/04/25 职场文书
2014年学校教学工作总结
2014/12/06 职场文书
2015年为民办实事工作总结
2015/05/26 职场文书