6.1使用WHERE子句
只检索所需数据需要指定搜索条件,搜索条件也称为过滤条件
在SELECT语句中,数据根据WHERE子句中指定的搜索条件进行过滤,WHERE子句在表名(FROM子句)之后给出
输入: SELECT prod_name,prod_price FROM products WHERE prod_price = 2.50;
分析: 这条语句从products表中检索两个列,但不返回所有行,只返回prod_price值为2.5的行
WHERE子句的位置:在ORDER BY子句的前面
6.2WHERE子句操作符
WHERE子句操作符
操作符 | 说明 |
---|---|
= | 等于 |
<> | 不等于 |
!= | 不等于 |
< | 小于 |
<= | 小于等于 |
> | 大于 |
>= | 大于等于 |
BETWEEN | 在指定的两个值之间 |
6.2.1检查单个值
输入:SELECT prod_name,prod_price FROM products WHERE prod_name = ‘fuses’
分析: 检查WHERE prod_name='fuses’语句,他返回prod_name的值为Fuses的一行。MySQL在执行匹配时默认不区分大小写
6.2.2不匹配检查
输入: SELECT vend_id,prod_name FROM products WHERE vend_id <> 1003;
分析: 列出不是由供应商1003制造的所有产品,上面也可以使用==!===
6.2.3范围值检查
输入: SELECT prod_name,prod_price FROM products WHERE prod_price BETWEEN 5 AND 10;
分析: 在使用BETWEEN时,必须指定两个值;所需范围的低端值和高端值,这两个值必须用AND关键字分隔,BETWEEN匹配范围中所有的值,包括指定的开始和结束值。如果给的值左高右低,则不报错,但是检索不到数据。
6.2.4空值检查
在创建表时,表设计人员可以指定其中的列是否可以不包含值,一个列不包含值时,称其为包含空值NULL
输入: SELECT prod_name FROM products WHERE prod_price IS NULL;
分析: 这条语句返回没有价格的所有产品
6.3小结
本章介绍了如何用SELECT语句的WHERE子句过滤返回的数据。我们学 习了如何对相等、不相等、大于、小于、值的范围以及NULL值等进行测 试。