示例使用的数据表在上一个博客中创建的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的操作符

上个示例中,我们使用到了‘=’这个操作符,下面列出所有条件操作符

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子句

上面的所有示例都是单个查询条件,但是实际中肯定会出现不止一个查询条件,这时候就可以用andor来组合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子句过滤数据的更多相关文章

  1. Mysql| 组合where子句过滤数据(AND,OR,IN,NOT)

    ysql 允许使用多个where子句,组合where子句允许使用两种方式使用:AND 和OR子句的方式使用.数据库中的操作符号:AND , OR , IN , NOT. AND:SELECT * FR ...

  2. 【MySQL】使用WHERE子句 - 过滤数据

    第6章 过滤数据 文章目录 第6章 过滤数据 1.使用WHERE子句 2.WHERE子句操作符 2.1.检查单个值 2.2.不匹配检查 2.3.范围值检查 2.4.空值检查 3.小结 简单记录 - M ...

  3. SQL基础-过滤数据

    一.过滤数据 1.使用WHERE子句 过滤数据:关键字WHERE SELECT 字段列表 FROM 表名 WHERE 过滤条件; 过滤条件一般由要过滤的字段.操作符.限定值三部分组成: 如: SELE ...

  4. mysql过滤数据

    1.大纲 WHERE - 学习如何使用WHERE子句根据指定的条件过滤行记录. AND运算符 - 介绍如何使用AND运算符以组合布尔表达式以形成用于过滤数据的复杂条件. OR运算符 - 介绍OR运算符 ...

  5. 《MySQL必知必会》过滤数据,数据过滤(where ,in ,null ,not)

    <MySQL必知必会>过滤数据,数据过滤 1.过滤数据 1.1 使用 where 子句 在SEL ECT语句中,数据根据WHERE子句中指定的搜索条件进行过滤. WHERE子句在表名(FR ...

  6. mysql必知必会(四、检索数据,五、排序检索数据,六、过滤数据,七、数据过滤)

    四.select语句 1.检索单个列 select prod_name from products; 2.检索多个列 select prod_name, prod_price from product ...

  7. MySQL学习笔记(二)——检索数据与过滤数据

    检索数据和过滤数据也就是平时用到最多的增删改查里面的查了. 一.数据检索 检索单个列: select column from table; 检索多个列:     select colunm1,colu ...

  8. 使用where 过滤数据

    --本章主要内容是MySQL中使用where搜索条件进行过滤数据. where条件在from子句后面给出,如下所示: select name,price from shops where price& ...

  9. ADO.NET 快速入门(十):过滤数据

    我们有很多方法来过滤数据.一种是在数据库命令级别,利用 where 子句查询过滤数据.另一种是在数据填充到 DataSet 以后过滤数据.本篇讨论后者.   一旦数据填充到 DataSet,你可以使用 ...

随机推荐

  1. 使用AddLayer方法加载shp文件中使用的Map、Dataset等对象详解

    内容源自:ArcGIS Engine+C#入门经典 方法二:使用axMapControl1对象的AddLayer方法加载ShapeFile文件 添加ShapeFile文件需要用到Map.Dataset ...

  2. webpack——简单入门

    1.介绍 Webpack 是当下最热门的前端资源模块化管理和打包工具.它可以将许多松散的模块按照依赖和规则打包成符合生产环境部署的前端资源.还可以将按需加载的模块进行代码分隔,等到实际需要的时候再异步 ...

  3. [GDKOI2016]染色大战

    Description

  4. vue MD5 加密

    确保vue项目中有MD5的依赖,当然没有的可以安装crypto模块. npm安装: npm install --save crypto 在main.js文件中将md5引入,可以全局使用的 import ...

  5. OpenvSwitch系列之ovs-vsctl命令使用

    Open vSwitch系列之一 Open vSwitch诞生 Open vSwitch系列之二 安装指定版本ovs Open vSwitch系列之三 ovs-vsctl 命令使用 OpenvSwit ...

  6. ESP8266开发之旅 网络篇⑪ WebServer——ESP8266WebServer库的使用

    授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...

  7. Shiro learning - 认证流程(3)

    Shiro认证流程 在学习认证流程之前,你应该先了解Shiro的基本使用流程 认证 身份认证: 证明用户是谁.用户需要提供相关的凭证principals(身份标识)和Credentials (凭证,证 ...

  8. 陈莉君教授: 回望踏入Linux内核之旅

    本文系转载,著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 作者: 陈莉君 来源: 微信公众号linux阅码场(id: linuxdev) 初次踏入Linux 几多耕耘,几多收获 ...

  9. 小白学 Python(17):基础数据类型(函数)(下)

    人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...

  10. 学习笔记51_MongoDB使用

    MongoDB的包: 例如:设置Mongodb端口 在命令行: F:\MongoDB>mongod.exe --port:3306 做集群: 安装和使用: 1.在服务中添加MongoDB ( 指 ...