经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
MySQL学习总结之路(第四章:运算符)
来源:cnblogs  作者:随风去远方  时间:2021/5/24 10:48:03  对本文有异议

目录

MySQL学习总结之路(第一章:服务与数据库管理)

MySQL学习总结之路(第二章:表)

MySQL学习总结之路(第三章:数据类型)

MySQL学习总结之路(第四章:运算符)

1.1、算数运算符

MySQL支持的算术运算符

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

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

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

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

  1. mysql> select 1/0;
  2. +------+
  3. | 1/0 |
  4. +------+
  5. | NULL |
  6. +------+
  7. 1 row in set (0.00 sec)

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

  1. mysql> select 1%2,mod(1,2);
  2. +------+----------+
  3. | 1%2 | mod(1,2) |
  4. +------+----------+
  5. | 1 | 1 |
  6. +------+----------+
  7. 1 row in set (0.00 sec)

 

1.2、比较运算符

MySQL支持的比较运算符

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

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

  1. mysql> select 1<>0,1<>1,null<>null;
  2. +------+------+------------+
  3. | 1<>0 | 1<>1 | null<>null |
  4. +------+------+------------+
  5. | 1 | 0 | NULL |
  6. +------+------+------------+
  7. 1 row in set (0.00 sec)

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

  1. mysql> select 1<=>1,1<=>0,null<=>null;
  2. +-------+-------+-------------+
  3. | 1<=>1 | 1<=>0 | null<=>null |
  4. +-------+-------+-------------+
  5. | 1 | 0 | 1 |
  6. +-------+-------+-------------+
  7. 1 row in set (0.02 sec)

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

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

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

  1. mysql> select 10 between 10 and 20,9 between 10 and 20;
  2. +----------------------+---------------------+
  3. | 10 between 10 and 20 | 9 between 10 and 20 |
  4. +----------------------+---------------------+
  5. | 1 | 0 |
  6. +----------------------+---------------------+
  7. 1 row in set (0.01 sec)

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

  1. mysql> select 'abcdeef' regexp 'ab','abcdef' regexp 'g','abcedf' regexp 'df';
  2. +-----------------------+---------------------+----------------------+
  3. | 'abcdeef' regexp 'ab' | 'abcdef' regexp 'g' | 'abcedf' regexp 'df' |
  4. +-----------------------+---------------------+----------------------+
  5. | 1 | 0 | 1 |
  6. +-----------------------+---------------------+----------------------+
  7. 1 row in set (0.01 sec)

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

1、in,使用格式为“a IN (value1,value2,…)”

2、IS NULL,使用格式为“a IS NULL”

3、IS NOT NULL,使用格式为“a IS NOT NULL”

4、LIKE,使用格式为“a LIKE %123%”

 

1.3、逻辑运算符

MySQL中的逻辑运算符

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

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

  1. mysql> select not 0,!0,not 1,not null;
  2. +-------+----+-------+----------+
  3. | not 0 | !0 | not 1 | not null |
  4. +-------+----+-------+----------+
  5. | 1 | 1 | 0 | NULL |
  6. +-------+----+-------+----------+
  7. 1 row in set (0.00 sec)

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

  1. mysql> select (1 and 1),(0 and 1),(3 and 1),(0 and null),(1 and null);
  2. +-----------+-----------+-----------+--------------+--------------+
  3. | (1 and 1) | (0 and 1) | (3 and 1) | (0 and null) | (1 and null) |
  4. +-----------+-----------+-----------+--------------+--------------+
  5. | 1 | 0 | 1 | 0 | NULL |
  6. +-----------+-----------+-----------+--------------+--------------+
  7. 1 row in set (0.00 sec)
  1. mysql> select 1 and NULL and 0;
  2. +------------------+
  3. | 1 and NULL and 0 |
  4. +------------------+
  5. | 0 |
  6. +------------------+
  7. 1 row in set (0.00 sec)
  8. mysql> select 1 and NULL and 3;
  9. +------------------+
  10. | 1 and NULL and 3 |
  11. +------------------+
  12. | NULL |
  13. +------------------+
  14. 1 row in set (0.00 sec)

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

  1. mysql> select (1 or 0),(0 or 0),(1 or NULL),(0 or NULL),(NULL or NULL);
  2. +----------+----------+-------------+-------------+----------------+
  3. | (1 or 0) | (0 or 0) | (1 or NULL) | (0 or NULL) | (NULL or NULL) |
  4. +----------+----------+-------------+-------------+----------------+
  5. | 1 | 0 | 1 | NULL | NULL |
  6. +----------+----------+-------------+-------------+----------------+
  7. 1 row in set (0.00 sec)

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

  1. mysql> select (0 xor 0),(1 xor 0),(1 xor 1),(1 xor null),(0 xor null),(null xor null);
  2. +-----------+-----------+-----------+--------------+--------------+-----------------+
  3. | (0 xor 0) | (1 xor 0) | (1 xor 1) | (1 xor null) | (0 xor null) | (null xor null) |
  4. +-----------+-----------+-----------+--------------+--------------+-----------------+
  5. | 0 | 1 | 0 | NULL | NULL | NULL |
  6. +-----------+-----------+-----------+--------------+--------------+-----------------+
  7. 1 row in set (0.00 sec)

 

1.4、位运算符

MySQL支持的位运算符

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

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

  1. mysql> select 2&3;
  2. +-----+
  3. | 2&3 |
  4. +-----+
  5. | 2 |
  6. +-----+
  7. 1 row in set (0.01 sec)

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

  1. mysql> select 2|3;
  2. +-----+
  3. | 2|3 |
  4. +-----+
  5. | 3 |
  6. +-----+
  7. 1 row in set (0.00 sec)

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

  1. mysql> select 2^3;
  2. +-----+
  3. | 2^3 |
  4. +-----+
  5. | 1 |
  6. +-----+
  7. 1 row in set (0.01 sec)

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

  1. mysql> select ~1,~18446744073709551614
  2. -> ;
  3. +----------------------+-----------------------+
  4. | ~1 | ~18446744073709551614 |
  5. +----------------------+-----------------------+
  6. | 18446744073709551614 | 1 |
  7. +----------------------+-----------------------+
  8. 1 row in set (0.01 sec)
  1. mysql> select bin(18446744073709551614);
  2. +------------------------------------------------------------------+
  3. | bin(18446744073709551614) |
  4. +------------------------------------------------------------------+
  5. | 1111111111111111111111111111111111111111111111111111111111111110 |
  6. +------------------------------------------------------------------+
  7. 1 row in set (0.03 sec)

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

  1. mysql> select 100>>3;
  2. +--------+
  3. | 100>>3 |
  4. +--------+
  5. | 12 |
  6. +--------+
  7. 1 row in set (0.00 sec)

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

  1. mysql> select 100<<3;
  2. +--------+
  3. | 100<<3 |
  4. +--------+
  5. | 800 |
  6. +--------+
  7. 1 row in set (0.00 sec)

1.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

此章节完成

原文链接:http://www.cnblogs.com/19930521zhang/p/14756406.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号