用了那么久MySql的数据库,总节了一下数据库的常用运算符,自己复习一下,以备以后参考。
1. 算术运算符(5种)
序号 | 运算符 | 作用 |
---|---|---|
1 | + | 加法运算 |
2 | - | 减法运算 |
3 | * | 乘法运算 |
4 | / | 除法运算,返回商。除数为 0,返回 NULL |
5 | %,MOD | 取余运算中。除数为 0,返回 NULL |
2. 比较运算符(15种)
SELECT 语句中的条件语句经常要使用比较运算符。比较结果为真,则返回 1,为假返回 0,比较结果不确定会返回 NULL。
运算符 | 作用 | 说明 |
---|---|---|
= | 等于 | 用来比较两边的内容是否相等,相等的话返回 1,不相等的话返回 0 |
<=> | 安全的等于 | 严格比较两个NULL值是否相,两个码均为NULL时,其所得值为1;而当一个码为NULL时,其所得值为0。 |
<> 或者 != | 不等于 | <> 和 != 用于判断数字、字符串、表达式是否不相等 |
<= | 小于等于 | 用来判断左边的数是否小于或者等于右边的数;小于或者等于,返回 1,否则返回 0;比较数含有 NULL,返回NULL。 |
>= | 大于等于 | 用来判断左边的数是否大于或者等于右边的数;如果大于或者等于,返回 1,否则返回0;比较数含有NULL,返回NULL。 |
> | 大于 | 用来判断左边的数是否大于右边的数;如果大于,返回 1,否则返回值0;比较数含有NULL,返回NULL。 |
< | 小于 | 用来判断左边数字是否小于右边的数,如果小于,返回1,否则返回0,比较数含有NULL,返回NULL。 |
IS NULL 或者 ISNULL | 判断值是否为空 | 检测一个值是否为 NULL,如果为 NULL,返回 1,否则返回值0。 |
IS NOT NULL | 判断值是否不为空 | 用来检测一个值是否为非 NULL,如果是非 NULL,返回 1,否则返回 0。 |
BETWEEN AND | 在两个值之间 | 用来判断表达式的值是否位于两个数之间,或者说是否位于某个范围内 |
NOT BETWEEN AND | 不在两个值之间 | 用来判断表达式的值是否不位于两个数之间,或者说是否不位于某个范围内 |
IN | 在集合中 | 判断某个数字或字符是否存下与集合中,如果存在返回1,不存在返回0 |
NOT IN | 不在集合中 | 判断某个数字或字符是否不存在集合中,如果不存在返回1,存在返回0 |
LIKE | 模糊匹配 | 搜索匹配字段中的指定内容。常用的通配符:%,_、escape |
REGEXP 或 RLIKE | 正则匹配 | 用于确定字符串是否匹配正则表达式。常用通配符:. 、* 、{n}、$、^、[] |
注意:比较运算符比较字符串的时候,不区分字符串的大小写。
3. 逻辑运算符(4种)
逻辑运算符:判断表达式的真假,返回值为布尔型,真:值(1 或 true)和假:值(0 或 false)。
运算符 | 作用 | 说明 |
---|---|---|
NOT 或者 ! | 逻辑非 | 返回和数相反的结果 :当数为 0(假)时,返回 1;当数为非零值时,返回 0;当数为 NULL 时,返回 NULL。 |
AND 或者 && | 逻辑与 | 当所有数都为非零值并且不为 NULL 时,返回 1;当一个或多个数为 0 时,返回 0;数中有任何一个为 NULL 时,返回NULL。 |
OR 和 || | 逻辑或 | 当两个数都为非 NULL 值时,如果有任意一个数为非零值,则返回值1,否则结果为 0;当有一个数为 NULL 时,如果另一个数为非零值,则返回1,否则结果为NULL;假如两个数均为 NULL 时,则返回NULL。 |
XOR | 逻辑异或 | 当任意一个数为 NULL 时,返回 NULL;对于非 NULL 的数,如果两个数都非 0 值或者都是为0 值,则返回 0;如果一个为0值,另一个为非 0 值,返回 1。 |
4. 位运算符(6种)
位运算符是在二进制数上进行计算的运算符。位运算会先将数变成二进制数,进行位运算。然后再将计算结果从二进制数变回十进制数。
运算符 | 作用 | 说明 |
---|---|---|
| | 位或 | 参与运算的两个二进制位有一个为 1 时,结果就为 1,两个都为 0 时结果才为 0。例如1|1结果为 1,0|0结果为0,1|0结果为1。** 任何数和 -1 进行位或运算时,最终结果都是 -1 的十进制数。 |
& | 位与 | 参与运算的两个二进制位都为 1 时,结果就为 1,否则为 0。例如1|1结果为 1,0|0结果为 0,1|0结果为 0。** 任何数和 -1 进行位与运算时,最终结果都为任何数本身的十进制数。 |
^ | 位异或 | 参与运算的两个二进制位不同时,结果为 1,相同时,结果为 0。 |
~ | 位取反运算符 | 位取反是将参与运算的数据按对应的补码进行反转,即 1 取反后变 0,0 取反后变为 1。 |
<< | 位左移 | 位左移是按指定值的补码形式进行左移,左移指定位数之后,左边高位的数值被移出并丢弃,右边低位空出的位置用 0 补齐。语法:expr << n |
>> | 位右移运算符 | 位右移是按指定值的补码形式进行右移,右移指定位数之后,右边低位的数值被移出并丢弃,左边高位空出的位置用 0 补齐。语法:expr >> n |
常用运算符的优先级
最高优先级为: !、BINARY、 COLLATE。最低优先级为: :=。
优先级由低到高顺序 | 运算符 |
---|---|
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 | ! |