MySql——使用where子句过滤数据
示例使用的数据表在上一个博客中创建的https://www.cnblogs.com/lbhym/p/11895968.html
参考资料:《Mysql必知必会》
1.使用where子句
示例如下:查询价格等于10.5的行
select * from commodity where price=10.5
输出:
1 1001 牙刷 10.5
2.where的操作符
上个示例中,我们使用到了‘=’这个操作符,下面列出所有条件操作符
| = | 等于 |
| <> | 不等于 |
| != | 不等于 |
| < | 小于 |
| > | 大于 |
| <= | 小于等于 |
| >= | 大于等于 |
| between | 在指定的两个值之间 |
3.检查单个值
在Mysql中,检查字段是不区分大小写的
比如:where name=‘ys’的结果和where name='YS'是一样的。我的数据当中没有字母,所以不做演示了。
4.不匹配检查
如下,查询typeid不等于1001的所有行
select * from commodity where typeid<>1001
其输出结果和!=是一样的:
select * from commodity where typeid!=1001
都是输出:
3 1002 茶几 999.9
4 1003 电视 3199
5 1003 冰箱 2999
6 1004 1 手机 1999
7 1004 2 手机 7699
8 1004 .3 手机 699.9
9 1005 T恤 21.5
10 1005 牛仔裤 99
5.范围值检查
如下,查询typeid在1002和1004之间的所有行,包括1002和1004
select * from commodity where typeid between 1002 and 1004
输出:
3 1002 茶几 999.9
4 1003 电视 3199
5 1003 冰箱 2999
6 1004 1 手机 1999
7 1004 2 手机 7699
8 1004 .3 手机 699.9
必须指定两个值,一个低端值和一个高端值,中间必须用and连接。
6.空值检查
如下,检查name为NULL的行,注意需要用is null。不是用=
select * from commodity where name is null
会输出所有name字段为null的行
7.组合where子句
上面的所有示例都是单个查询条件,但是实际中肯定会出现不止一个查询条件,这时候就可以用and或or来组合where子句
示例1,查询价格大于20的1001型商品
select * from commodity where price>20 and typeid=1001
输出:
2 1001 毛巾 21.5
示例2,查询价格大于3000的1003型商品或1004型商品
select * from commodity where typeid=1003 or typeid=1004 and price>3000
大家仔细看看上面的代码,似乎没什么问题,类型等于1003或类型等于1004并且价格大于3000
输出结果:
4 1003 电视 3199
5 1003 冰箱 2999
7 1004 2 手机 7699
但是从结果看是错误的,这是由于计算次序的问题。在mysql中and拥有更高的优先级,所以看似没问题的组合被mysql错误的组合了,where后面的条件可以看成
(price>3000 and typeid=1003) or typeid=1004
可以用小括号来组合where后面的条件,小括号具有比and和or更高的优先级。
所以,正确的写法如下:
select * from commodity where (typeid=1003 or typeid=1004) and price>3000
输出:
4 1003 电视 3199
7 1004 2 手机 7699
8.not和in操作符
in用来指定条件范围
如下,查询商品类型等于1001,1002的所有行
select * from commodity where typeid in (1001,1002)
输出:
1 1001 牙刷 10.5
2 1001 毛巾 21.5
3 1002 茶几 999.9
需要注意的是,大家不要当成between的另外一种写法,小括号中可以有N个值,用逗号隔开,最后会返回指定字段出现在小括号中的所有行。
in和or的功能其实有些相同,但是in在遇到更多条件时会显得更加简洁。而且in的执行效率更快,最大的优点是可以包含select语句。比如小括号里面你不确定是哪些值,需用实时的查询,那么select语句就可以写在小括号里面。
not用来否定后面跟着的条件。
如下,查询商品类型不等于1001,1002的所有行
select * from commodity where typeid not in (1001,1002)
输出:
4 1003 电视 3199
5 1003 冰箱 2999
6 1004 1 手机 1999
7 1004 2 手机 7699
8 1004 .3 手机 699.9
9 1005 T恤 21.5
10 1005 牛仔裤 99
not支持对between、in、exists的取反。
MySql——使用where子句过滤数据的更多相关文章
- Mysql| 组合where子句过滤数据(AND,OR,IN,NOT)
ysql 允许使用多个where子句,组合where子句允许使用两种方式使用:AND 和OR子句的方式使用.数据库中的操作符号:AND , OR , IN , NOT. AND:SELECT * FR ...
- 【MySQL】使用WHERE子句 - 过滤数据
第6章 过滤数据 文章目录 第6章 过滤数据 1.使用WHERE子句 2.WHERE子句操作符 2.1.检查单个值 2.2.不匹配检查 2.3.范围值检查 2.4.空值检查 3.小结 简单记录 - M ...
- SQL基础-过滤数据
一.过滤数据 1.使用WHERE子句 过滤数据:关键字WHERE SELECT 字段列表 FROM 表名 WHERE 过滤条件; 过滤条件一般由要过滤的字段.操作符.限定值三部分组成: 如: SELE ...
- mysql过滤数据
1.大纲 WHERE - 学习如何使用WHERE子句根据指定的条件过滤行记录. AND运算符 - 介绍如何使用AND运算符以组合布尔表达式以形成用于过滤数据的复杂条件. OR运算符 - 介绍OR运算符 ...
- 《MySQL必知必会》过滤数据,数据过滤(where ,in ,null ,not)
<MySQL必知必会>过滤数据,数据过滤 1.过滤数据 1.1 使用 where 子句 在SEL ECT语句中,数据根据WHERE子句中指定的搜索条件进行过滤. WHERE子句在表名(FR ...
- mysql必知必会(四、检索数据,五、排序检索数据,六、过滤数据,七、数据过滤)
四.select语句 1.检索单个列 select prod_name from products; 2.检索多个列 select prod_name, prod_price from product ...
- MySQL学习笔记(二)——检索数据与过滤数据
检索数据和过滤数据也就是平时用到最多的增删改查里面的查了. 一.数据检索 检索单个列: select column from table; 检索多个列: select colunm1,colu ...
- 使用where 过滤数据
--本章主要内容是MySQL中使用where搜索条件进行过滤数据. where条件在from子句后面给出,如下所示: select name,price from shops where price& ...
- ADO.NET 快速入门(十):过滤数据
我们有很多方法来过滤数据.一种是在数据库命令级别,利用 where 子句查询过滤数据.另一种是在数据填充到 DataSet 以后过滤数据.本篇讨论后者. 一旦数据填充到 DataSet,你可以使用 ...
随机推荐
- Ubuntu18.04安装NVIDIA显卡驱动
1. 查看GPU型号 lspci | grep -i nvidia 我是 GeForce GTX 960M 2. NVIDIA官网下载驱动: https://www.nvidia.com/Downlo ...
- Java学习笔记之封装与继承
封装 1,将属性定义为私有的(private) 不能通过 对象名.属性 来直接访问,但是可以通过方法来间接的访问, 2,封装的意义:公有属性可以被随意修改,并且不能被程序察觉.封装后,别人通过 ...
- MySQL 插入记录时自动更新时间戳
将字段设置成timestamp类型,同时默认值设置成 CURRENT_TIMESTAMP.
- Halcon一日一练:获取孔位
本例程是用于获取安装螺丝孔在图像中对应的坐标位置,并显示该坐标位,如上图所示. read_image(Image,'rim.png')//读取图像 dev_close_window()//关闭窗口 g ...
- 【阿里云IoT+YF3300】6.物联网设备报警配置
纵然5G时代已经在时代的浪潮中展现出了它的身影,但是就目前的物联网环境中,网络问题仍旧是一个比较突出的硬伤.众所周知,在当前的物联网规划中,与其说是实现万物互联,倒不如说是行业指标数据监控.对于一些特 ...
- C语言I博客作业05
内容 答案 这个作业属于哪个课程 C语言程序设计II 这个作业要求在哪里 C语言I作业05 我在这个课程的目标是 更熟练的运用编译函数问题 这个作业在哪个具体方面帮助我实现目标 PTA实验作业 参考文 ...
- 你不知道的DIV+CSS的命名规则
搜索引擎优化(seo)有很多工作要做,其中对代码的优化是一个很关键的步骤.为了更加符合SEO的规范,下面是目前比较好的CSS+DIV的命名规则 1DIV CLASS或者ID 页头:header 登录条 ...
- Android SDK安装与环境变量的配置(windows系统)
(一)下载Android SDK压缩包 解压后即可(全英文路径,以免后续出现乱码) (1)下载地址:http://tools.android-studio.org/index.php/sdk
- python-从文件中读取数据
一.读取整个文件 learnFile.py 绝对路径 # coding=UTF-8 import sys reload(sys) with open(r'C:\Users\zhujiachun\Des ...
- PhpStorm10和Apache24配置多项目开发环境
PhpStorm10和Apache24配置多项目开发环境 Apache配置 httpd.conf LoadModule vhost_alias_module modules/mod_vhost_ali ...