条件语句
AND 语句
MySQL 的 AND 用来在增删改查语句中连接多个过滤条件。
语法:
WHERE condition1
AND condition2
...
AND condition_n;
参数:
condition1, condition2, ... condition_n: SQL 语句中必须满足的条件。
例子1:AND
SELECT * FROM cus_tbl WHERE cus_firstname = 'Andy' AND cus_id > 3;
OR 语句
在 MySQL 中,使用 OR 连接一个或多个条件时,只要满足其中任何一个条件即可返回。
语法:
WHERE condition1
OR condition2
...
OR condition_n;
参数:
condition1, condition2, ... condition_n: SQL 语句中的所有过滤条件。
SELECT *
FROM cus_tbl
WHERE cus_firstname = 'Ajeet'
OR cus_id > 100;
注意: 从输出结果中就可以看出,虽然 cus_id 小于 100,但是也是正确的查询结果。
AND 和 OR
在 MySQL 增、删、改、查语句中,你也可以同时使用 AND 和 OR 来连接过滤条件,不过一定要注意小括号
的范畴。
语法:
WHERE condition1
AND condition2
...
OR condition_n;
参数:
condition1, condition2, ... condition_n: SQL 语句中必须满足的条件。
例子1:
SELECT *
FROM students
WHERE (course_name = 'Java' AND student_name = 'Andy')
OR (student_id < 2);
LIKE 语句
在 MySQL 中,LIKE 条件作为 WHERE 子句的一部分,来实现 SQL 语句中的模糊匹配。
语法:
expression LIKE pattern [ ESCAPE 'escape_character' ]
参数:
expression: SQL 语句检索的列。
pattern: 包含模糊匹配的字符串表达式。
escape_character: 可选项,匹配通配符,例如 % 或 _。如果没有该选项,MySQL 会自动检索完全匹配项
例子1: 使用 % (百分号) 通配符:
SELECT officer_name
FROM officers
WHERE address LIKE 'Luck%';
例子2: 使用 _ (下划线) 通配符:
SELECT officer_name
FROM officers
WHERE address LIKE 'Luc_now';
例子2: 使用 NOT 运算符:
您还可以在 MySQL LIKE 条件下使用 NOT 运算符。本示例说明将 % 通配符与 NOT 运算符一起使用。
SELECT officer_name
FROM officers
WHERE address NOT LIKE 'Luck%';
注意:在上面的示例中, 你可以看到 addresses 只显示了 NOT LIKE 'Luck%' 的数据。
IN 语句
MySQL 中的 IN 条件可以减少 SQL 语句中多个 OR 条件的使用。
语法:
expression IN (value1, value2, .... value_n);
参数:
- expression: 指定的表达式。
- value1, value2, ... or value_n: 如果这些值中的任何一个与表达式的值匹配,则 IN 条件将返回 true。这是一种测试指定的值是否与表达式匹配的快速方法。
例子1:使用IN
SELECT *
FROM officers
WHERE officer_name IN ('Ajeet', 'Vimal', 'Deepika');
对比一下 IN 相对于 OR 的优势:
例子2:使用OR
SELECT *
FROM officers
WHERE officer_name = 'Ajeet'
OR officer_name = 'Vimal'
OR officer_name = 'Deepika';
SQL 执行结果相同,但是 IN 条件的代码量更少。
NOT语句
MySQL 的 NOT 条件与 IN 条件账号相反,用来在 SQL 语句中判断与表达式不匹配的项。
语法:
NOT condition
参数
condition: 要取反的条件。
例子1: NOT 与 IN 条件
SELECT *
FROM officers
WHERE officer_name NOT IN ('Ajeet','Vimal','Deepika');
例子2:NOT 与 IS NULL 条件
SELECT *
FROM officers
WHERE officer_name IS NOT NULL;
例子3:NOT 与 LIKE 条件
SELECT *
FROM officers
WHERE officer_name NOT LIKE 'A%';
例子4:NOT 与 BETWEEN 条件
SELECT *
FROM officers
WHERE officer_id NOT BETWEEN 3 AND 5;
IS NULL 语句
MySQL 的 IS NULL 条件检查 SQL 语句中表达式的值是否为 NULL。
语法:
expression IS NULL
参数
expression:指定的表达式。
例子1:
SELECT *
FROM officers
WHERE officer_name IS NULL;
返回结果是空,这说明表中没有列 officer_name 值为 NULL 的记录。
IS NOT NULL 语句
MySQL 的 IS NOT NULL 条件用来匹配 SQL 语句中表达式的值不为 NULL。
语法:
expression IS NOT NULL
参数
expression: 表达式的值
例子1:
SELECT *
FROM officers
WHERE officer_name IS NOT NULL;
注意: 返回结果是数据表中的所有记录,因为所有列的值都不是 NULL。
BETWEEN 语句
MYSQL 的 BETWEEN 条件在 SQL 语句中指定表达式值的范围。
语法:
expression BETWEEN value1 AND value2;
参数:
- expression: 指定列的表达式。
- value1 and value2: 指定列的表达式的范围。
例子1:BETWEEN 与数字类型的值
SELECT *
FROM officers
WHERE officer_id BETWEEN 1 AND 3;
注意: 上面示例中,可以看到仅有 3 条记录被返回。
例子2: BETWEEN 与日期类型的值
MySQL BETWEEN 条件还可以允许你根据日期检索记录。
SELECT *
FROM employees
WHERE working_date BETWEEN CAST ('2015-01-24' AS DATE) AND CAST ('2015-01-25' AS DATE);
注意: 可以看到,只有满足日期范围的记录被返回。