1、WHERE 子句条件操作符

包括:> 、<、>=、<=、!= 、=、BETWEEN ... AND ...(在指定的两个值之间)

示例:

1)select * from student where stu_id=267;

2)select * from student where stu_id<267;

3)select * from student where stu_id between 267 and 305;

空值检查:使用 NULL 关键字

select * from student where stu_id is null;

2、WHERE 子句逻辑操作符

1) AND 

    如果需要使用多个列一起过滤才能查询出要查询的结果,可以使用 AND 进行连接。

select * from student where stu_name="test13" and stu_id=26;

 2)OR

与 AND 相反,只要匹配任一条件就可以。

select * from student where stu_id=26 or stu_id=27;

 3)计算次序

WHERE 可以包含任意数目的 AND 和 OR。允许两者结合以进行复杂和高级的过滤。

AND 的优先级高于 OR。也就是说在 SQL 中如果 AND 和 OR 混合使用,那么会优先运算 AND 然后在运算 OR。

例如:

SELECT * FROM products WHERE  pro_id = 3 OR  pro_id=4 AND pro_price>10;

那么对于 SQL 的理解是:查询 id 为 4 并且价格大于 10 或者 id 为3 的任意条件的产品信息。

如果要实现查询 id 为 3 或 4 并且价格大于 10 的产品信息,则需要使用圆括号来对操作符进行分组。

SELECT * FROM products WHERE (pro_id = 3 OR  pro_id=4) AND pro_price>10;

小贴士:如果 AND 和 OR 同时使用,不管什么情况下,最好都使用圆括号来进行分组,避免造成不必要的歧义。

3、 IN 

IN 用来指定条件范围,范围中的每个条件都可以进行匹配。用逗号分隔,全部括在圆括号中。

SELECT * FROM products WHERE pro_id IN (3, 4) AND pro_price>10;

作用和 OR 相同。使用 IN 的优点:

  • 在使用较长的选项清单时,使用 IN 更为清楚直观。
  • 使用 IN 时,计算次序也更加清楚。
  • IN 比 OR 执行更快。
  • IN 的最大有点是可以包含其他 SELECT 语句。

4、NOT IN

用来否定后面跟的条件。

SELECT * FROM student WHERE  stu_id NOT IN(26, 303); //表示查询 stu_id 为 26、303 之外的学生信息






MySql:SELECT 语句(三) WHERE 指定查询条件的更多相关文章

  1. 【MYSQL】update/delete/select语句中的子查询

    update或delete语句里含有子查询时,子查询里的表不能在update或是delete语句中,如含有运行时会报错:但select语句里含有子查询时,子查询里的表可以在select语句中. 如:把 ...

  2. 指定查询条件,查询对应的集合List(单表)

    TestDao.java(测试类) @Test public void findCollectionByConditionNoPage(){  ApplicationContext ac = new ...

  3. mysql SELECT语句 语法

    mysql SELECT语句 语法,苏州大理石方箱 作用:用于从表中选取数据.结果被存储在一个结果表中(称为结果集). 语法:SELECT 列名称 FROM 表名称 以及 SELECT * FROM ...

  4. 判断语句(if...else)if...else语句是在指定的条件成立时执行代码,在条件不成立时执行else后的代码

    判断语句(if...else) if...else语句是在指定的条件成立时执行代码,在条件不成立时执行else后的代码. 语法: if(条件) { 条件成立时执行的代码 } else { 条件不成立时 ...

  5. MySQL select 语句指定字段查询

    指定字段查询 SELECT 语法 SELECT [ALL | DISTINCT] {* | table.* | [table.field1[as alias1][,table.field2[as al ...

  6. mysql select语句查询流程是怎么样的

    select查询流程是怎么样的 mysql select查询的数据是查询内存里面,如果没有查询的数据没有在内存,就需要mysql的innodb引擎读取磁盘,将数据加载的内存后在读取.这就体现了,mys ...

  7. JAVA / MySql 编程—— 第三章 高级查询(一)

    1.        修改表: (1)修改表名语法: ALTER TABLE <旧表名> RENAME [ TO ] <新表名>: 注意:其中[TO]为可选参数,使用与否不影响结 ...

  8. MySQL SELECT语句

    说明:MySQL的offset第一行是0 位置指的是在SELECT语句中第几个出现的字段,如:1,则代表用第一个出现的字段来分组. SELECT语句: SELECT  select_expr1 [,s ...

  9. MySQL Select语句的执行顺序

    源文章:How is a query executed in MySQL? 当执行SQL的Select查询语句时,SQL指令的执行顺序如下: FROM 子句 WHERE 子句 GROUP BY 子句 ...

随机推荐

  1. cut语法

    cut是一个选取命令,就是将一段数据经过分析,取出我们想要的.一般来说,选取信息通常是针对“行”来进行分析的,并不是整篇信息分析的. (1)其语法格式为:cut  [-bn] [file] 或 cut ...

  2. activity select problem(greedy algorithms)

    many activities will use the same place, every activity ai has its'  start time si and finish time f ...

  3. 剑指Offer 17. 树的子结构 (二叉树)

    题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 题目地址 https://www.nowcoder.com/practice/6e196c44c7 ...

  4. HttpURLConnection与HttpClient浅析

    转自:https://blog.csdn.net/u012838207/article/details/82867701 HttpURLConnection与HttpClient浅析 1. GET请求 ...

  5. React Native 安卓 程序运行报错: React Native version mismatch(转载)

    这个问题已经得到解决,参照stackoverflow上的问题:https://stackoverflow.com/que...这个问题的原因就处在Android工程中app/build.gradle中 ...

  6. leetcode 3.Longest Substring Without Repeating Charcters

    在一个字符串中寻找出最长的无重复字符的子串的,在不断的后续检索中需要去掉前面一个重复的字符,那么就是需要记录之前所出现过的字符的,在这里需要利用hashmap来记录字符和其出现的位置之间的映射关系的, ...

  7. 为什么要将Apache与Tomcat集成?(或不)

    Why should I integrate Apache with Tomcat? (or not) There are many reasons to integrate Tomcat with ...

  8. Git图形化界面客户端

    Git图形化界面客户端大汇总 文,还在不断更新,网上搜到的同名文章都是未经同意就从这里复制过去的) 一.TortoiseGit - The coolest Interface to Git Versi ...

  9. ios-屏幕适配(代码)

    由于第一个项目中98%的界面都用到UITableView,所以适配仅判断此.知道手工敲代码的繁复,遂传一部分,如果有更优的方法,欢迎提出. 如下图,图中提到的宏定义是在prefix.pch预编绎文件里 ...

  10. Linux 文件查看,文件夹切换,权限查看

    当前用户只操作当前用户目录 1. 输入终端显示内容: 用户 @ 系统 : 路径信息  $ $ 表示普通用户  家目录 # 表示超级用户  家目录 [sudo -i ]  使用root用户 :   使用 ...