MySql:SELECT 语句(三) WHERE 指定查询条件
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 指定查询条件的更多相关文章
- 【MYSQL】update/delete/select语句中的子查询
update或delete语句里含有子查询时,子查询里的表不能在update或是delete语句中,如含有运行时会报错:但select语句里含有子查询时,子查询里的表可以在select语句中. 如:把 ...
- 指定查询条件,查询对应的集合List(单表)
TestDao.java(测试类) @Test public void findCollectionByConditionNoPage(){ ApplicationContext ac = new ...
- mysql SELECT语句 语法
mysql SELECT语句 语法,苏州大理石方箱 作用:用于从表中选取数据.结果被存储在一个结果表中(称为结果集). 语法:SELECT 列名称 FROM 表名称 以及 SELECT * FROM ...
- 判断语句(if...else)if...else语句是在指定的条件成立时执行代码,在条件不成立时执行else后的代码
判断语句(if...else) if...else语句是在指定的条件成立时执行代码,在条件不成立时执行else后的代码. 语法: if(条件) { 条件成立时执行的代码 } else { 条件不成立时 ...
- MySQL select 语句指定字段查询
指定字段查询 SELECT 语法 SELECT [ALL | DISTINCT] {* | table.* | [table.field1[as alias1][,table.field2[as al ...
- mysql select语句查询流程是怎么样的
select查询流程是怎么样的 mysql select查询的数据是查询内存里面,如果没有查询的数据没有在内存,就需要mysql的innodb引擎读取磁盘,将数据加载的内存后在读取.这就体现了,mys ...
- JAVA / MySql 编程—— 第三章 高级查询(一)
1. 修改表: (1)修改表名语法: ALTER TABLE <旧表名> RENAME [ TO ] <新表名>: 注意:其中[TO]为可选参数,使用与否不影响结 ...
- MySQL SELECT语句
说明:MySQL的offset第一行是0 位置指的是在SELECT语句中第几个出现的字段,如:1,则代表用第一个出现的字段来分组. SELECT语句: SELECT select_expr1 [,s ...
- MySQL Select语句的执行顺序
源文章:How is a query executed in MySQL? 当执行SQL的Select查询语句时,SQL指令的执行顺序如下: FROM 子句 WHERE 子句 GROUP BY 子句 ...
随机推荐
- the principle of redbalck tree
- MyEclipse 启动慢,优化
找到安装目录,修改myeclipse.ini 文件: -Xms2048m -Xmx8192m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=256m
- MySQL - 常见的存储引擎
数据库存储引擎是数据库底层软件组织,数据库管理系统(DBMS)使用数据引擎进行创建.查询.更新和删除数据,不同的存储引擎... 存储引擎 数据库存储引擎: 是数据库底层软件组织,数据库管理系统(DBM ...
- 常用解压包命令----tar--rar
systemctl stop firewalld --关闭 linux服务器防火墙 1.*.tar 用 tar –xvf 解压 2.*.gz 用 gzip -d或者gunzip 解压 3.*. ...
- 一个页面从输入url到加载完成的过程都发生了什么,请详细说明
1.首先,在浏览器地址栏中输入url 2.浏览器先查看浏览器缓存-系统缓存-路由器缓存,如果缓存中有,会直接在屏幕中显示页面内容.若没有,则跳到第三步操作 3.在发送http请求前,需要域名解析(DN ...
- 备忘:EBS参考链接
帮助手册查阅网址http://docs.oracle.com/cd/V46499_01/current/html/docset.html 官方 http://www.oracleappshub.co ...
- 第二个web网页
1.源代码 <!DOCTYPE html> <html> <head> <meta charset="UTF-8">-------- ...
- java android 捕获未处理异常
1. 定义一个异常处理类 public class ExceptionHandler implements Thread.UncaughtExceptionHandler { public Excep ...
- 查看进程在CPU和内存占用的命令
1.使用top命令 输入M表示按内存排序,也就是RES这一列从大到小排序了 它占用了3.3%的内存,用134568除以4030416结果就是3.3左右 也就是说 总物理内存是3.84GB RES这一列 ...
- PS 给照片换背景
1. 打开一张照片,导入证件照 2. 点击选择 => 选择并遮住 (快捷键 command + option + r) 3. 点击快速选择工具,将属性设置里面的视图模式选择为洋葱皮,鼠标点击需要 ...