SQL语句学习5——数据过滤

1.1AND操作符

如果需要通过多个列过滤数据,那么可使用AND操作符给where子句附加条件

SELECT 输出列名1,输出列名2……
FROM 表 
WHERE 过滤列名1,过滤列名2,……;

在这里插入图片描述
上述表示将vend_id=1001和prod_price=5.99作为数据过滤条件

补充:当每新增一个过滤条件时,便增加一个AND

1.2 OR操作符

OR操作符是匹配任意一条件,相比较AND(AND是匹配同时满足所有过滤条件)

SELECT 输出列名1,输出列名2……
FROM 表名
WHERE 过滤列名1 OR 过滤列名2 OR 列名3……;

在这里插入图片描述

1.3计算次序

当组合AND和OR时,那么就会产生先执行那个的顺序问题。那么MySQL定义AND的优先级要比OR的优先级高,为了解决这种可能存在的未知的错误,最好的办法是使用圆括号明确地分组相应的操作。

SELECT 输出列名1,输出列名2……
FROM 表名
WHERE (过滤列名1 OR过滤列名2)AND 过滤列名3;

在这里插入图片描述

1.4 IN操作符

圆括号在where子句中还有另外一种用法。IN操作符用来指定条件范围中的每个条件都可以进行匹配,IN取值合法值的由逗号分隔的清单,这种用法与OR相同

SELECT 输出列名1,输出列名2…… FROM 表名 WHERE 过滤列名 IN (取值1,取值2……);

在这里插入图片描述
补充:虽然说IN的用法和OR的用法相同,但是相比较来说,IN执行更快

1.4 NOT操作符

WHERE子句中的NOT操作符有且只有一个功能,那就是否定它之后的任何条件

SELECT 输出列名1,输出列名2…… FROM 表名 WHERE 过滤列名1 NOT 否定的条件;

在这里插入图片描述
上面SQL语句表示的意思是:输出vend_id不为1001,1003的所有满足该条件的行

MySQL支持使用NOT对IN,BETWEEN和EXISTS子句取反

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值