MySQL | 条件查询的语句(二)

MySQL | 条件查询的语句(二)

数据操作语言:条件查询(二)

逻辑运算符

序号表达式意义例子
1AND与关系age > 18 AND sex = "男"
2OR或关系empno = 8000 OR deptno = 20
3NOT非关系NOT deptno =20
4XOR异或关系age > 18 XOR sex = "男"
SELECT
    ename,deptno
FROM t_emp
WHERE NOT deptno IN(10,20);
WHERE NOT deptno IN(10,20) XOR sal>=2000;

二进制按位运算

  • 二进制位运算的实质是将参与运算的两个操作数,按对应的二进制数逐位进行逻辑运算。
SELECT 3 & 7;

08

按位运算符
序号表达式意义例子
1&位与关系3 & 7
2\位或关系`37`
3~位取反`~10
4^位异或3 ^ 7
5<<左移10 << 1
6>>右移10 >> 1

WHERE 子句的注意事项

  • WHERE 子句中,条件执行的顺序是从左到右的。所以我们应该把索引条件,或者筛选掉记录最多的条件写在最左侧

10

  • 子句优先级
    • 索引条件最左边,再是筛选最多的,最后是普通条件

各种子句的执行顺序

  • 条件查询中,WHERE 子句应该是第几个执行?

FROM -> WHERE -> SELECT -> ORDER BY -> LIMIT