霍格沃兹测试开发

DQL 表查询操作 - 条件查询

霍格沃兹测试开发学社

ceshiren.com

目录

  • 条件查询语法
  • 比较运算符
  • 逻辑运算符
  • 通配符

条件查询语法

-- 条件查询
SELECT 列名 FROM 表名 WHERE 条件表达式

比较运算符

运算符 说明
> < <= >= = <> != 大于、小于、小于等于、大于等于、等于、不等于
BETWEEN...AND... 范围限定
IN 子集限定
LIKE '%or%' 模糊查询
IS NULL 为空

比较大小

  • 语法:WHERE <列名> [> < <= >= = <> !=] <值>
-- 查询出生日期晚于 1965-01-01 的员工编号、姓名和生日
SELECT 
    emp_no, first_name, last_name, birth_date
FROM
    employees
WHERE
    birth_date > '1965-01-01';

使用 BETWEEN 进行模糊查询

  • 语法:WHERE <列名> [NOT] BETWEEN <起始表达式> AND <结束表达式>
  • <起始表达式><结束表达式> 的顺序不能颠倒
-- 查询年薪介于 70000 到 70003 之间的员工编号和年薪
SELECT 
    emp_no, salary
FROM
    salaries
WHERE
    salary BETWEEN 70000 AND 70003;

使用 IN 进行模糊查询

  • 语法:WHERE <列名> IN <(常量列表)>
  • (常量列表) 中各常量值用逗号隔开
-- 查询入职日期为 1995-01-27 和 1995-03-20 日的员工信息
SELECT 
    *
FROM
    employees
WHERE
    hire_date IN ('1995-01-27', '1995-03-20');

判断是否为空

  • 语法:WHERE <列名> IS [NOT] NULL
-- 选择 hog_demo 为当前数据库
USE hog_demo;

-- 更新 student 表中 id 为 2 的 age 值为 NULL
UPDATE student SET age = NULL WHERE id = 2;

-- 查询学生表中年龄为 NULL 的学生信息
SELECT 
    *
FROM
    student
WHERE
    age IS NULL;

逻辑运算符

运算符 说明
AND && 多个条件同时成立
OR || 多个条件任一成立
NOT 不成立
-- 查询名字为 Lillian 并且姓氏为 Haddadi 的员工信息
SELECT 
    *
FROM
    employees
WHERE
    first_name = 'Lillian'
        AND last_name = 'Haddadi';

-- 查询名字为 Lillian 或者姓氏为 Terkki 的员工信息
SELECT 
    *
FROM
    employees
WHERE
    first_name = 'Lillian'
        OR last_name = 'Terkki';

-- 查询名字为 Lillian 并且性别不是女的员工信息
SELECT 
    *
FROM
    employees
WHERE
   first_name = 'Lillian'
   and not gender='F';

通配符

运算符 说明
% 匹配任意多个字符
- 匹配一个字符
-- 查询名字中包含 fai 的员工的信息
SELECT 
    *
FROM
    employees
WHERE
    first_name LIKE '%fai%';

-- 查询名字中 fa 开头的名字长度为 3 位的员工信息
SELECT 
    *
FROM
    employees
WHERE
    first_name LIKE 'fa_';