MySQL条件查询
语法:
①SELECT 查询列表(可以包括:字段、表达式、常量值、几个拼在一起的,构成的表)
②FROM 表名(原始表)
③WHERE (理解为当...筛选条件=TRUE或筛选条件=FALSE)
筛选条件
执行顺序是:231
根据筛选条件的不同分类:
1.按条件表达式筛选
条件运算符:> < = !=或<> <= >=
2.按逻辑表达式筛选
逻辑运算符:
作用连接条件表达式
Java中的: && || !
和
MySQL中的:and or not
&& 和 and:两个条件都为true,结果为true,反之为false
|| 和 or:只要有一个条件为true,结果为true,反之为false
! 和 not: 如果条件本身为false,结果为true,反之为false
3.模糊查询
like一般和通配符使用
通配符:
%任意多个字符,包括0个,不能表示null
_任意单个字符between and(英语在什么什么之间)这也是
特点:
1.可以提高语句简洁度
2.包含临界值
3.等价于 >= <=
类型必须一致,或者可以影式的转换in
含义:判断某字段的值是否属于in列表中的某一项
特点:
1.使用in提高语句简洁度
2.in列表的值的类型(就是字段) 必须统一或兼容(可以隐式转换)
3.等价于 = 号
4.不支持通配符is null
1.= != <> 不能判断null值
需要用
2.is null 或 is not null 可以判断null值
3.is 和 null 不可分割<=>安全等于
含义:判断是否等于,如果等于返回true否则返回false
作用:
1.可以判断null值
2.还可以判断普通值缺点:
可读性差IS NULL pk <=>
IS NULL;仅仅可以用来判断null值,建议使用
<=>;既可以判断null值,又可以判断普通值,可读性比较低IFNULL(A,B) 如果A是空的那么IFNULL的结果就是B,反之A不为空那么IFNULL的结果就是A
#一.按条件表达式查询
/*
案例1:查询工资>12000的员工信息
*/
SELECT
*
FROM
employees
WHERE
salary > 12000;
/*
案例2:查询部门编号不等于90号的员工名和部门
*/
SELECT
last_name,
department_id
FROM
employees
WHERE
department_id <> 90;#推荐使用
department_id != 90;
#二、逻辑表达式筛选
/*
案例1:查询工资在10000到20000之间的员工名、工资以及奖金
*/
SELECT
last_name,
salary,
commission_pct
FROM
employees
WHERE
salary >= 10000
AND
salary <= 20000;
#案例2:查询部门编号不在90到110之间 或者工资高于15000的信息
SELECT * FROM employees
WHERE
NOT ( department_id >= 90 AND department_id <= 110 ) OR salary > 15000;#非 大于等于90小于等于110的数,或者工资在15000以上
department_id<90 OR department_id>110 OR salary>15000;#小于90 或者 大于110 或者工资在15000以上
#三、模糊查询
/*
案例1:查询员工名中 包含字符a的员工信息
因为SQL不区分大小写所以大A小a都有
*/
SELECT
*
FROM
employees
WHERE
last_name LIKE '%a%';
/*
%百分号代表通配符 任意多个字符。类似于Windows里的*
''数据库中字符字符串都用单引号标识
*/
/*
案例2:查询员工名中 第三个字符为e,第五个字符为a的员工名和工资
因为SQL不区分大小写所以大E小e都有
*/
SELECT
last_name,
salary
FROM
employees
WHERE
last_name LIKE '__n_l%';
/*
后面要加%号否则表示 五个字符,第三个为n,第五个为l。
*/
/*
案例3:查询员工名中第二个字符为 _ 的员工名
*/
SELECT
last_name,
salary
FROM
employees
WHERE
last_name LIKE '_$_%' ESCAPE '$';
last_name LIKE '_\_%';
\右斜杠转译字符
当条件需要 右斜杠时 可以使用 ESCAPE声明转译字符
#2.between and(英语在什么什么之间)这也是
/*
案例1:查询员工编号在100到120之间的员工信息
*/
SELECT
*
FROM
employees
WHERE
employee_id >=100 AND employee_id <=120;
-- ------------------上下结果一样,下面的更加简洁------------------------------------
SELECT
*
FROM
employees
WHERE
employee_id BETWEEN 100 AND 120;
#3.in
/*
案例查询员工的工种编号是 IT_PROG 。AD_VP 、AD_PRES 中的一个员工 和工种编号
*/
SELECT
last_name,
job_id
FROM
employees
WHERE
job_id ='IT_PROG' OR job_id ='AD_VP' OR job_id ='AD_PRES';
-- ------------------上下结果一样,下面的更加简洁------------------------------------
SELECT
last_name,
job_id
FROM
employees
WHERE
job_id IN('IT_PROG','AD_VP','AD_PRES');
#is null
/*
案例1:查询没有奖金的的员工名和奖金率
*/
SELECT
last_name,
commission_pct
FROM
employees
WHERE
commission_pct = NULL;
-- -------------------无法显示出结果 因为 这种=号 不能判断null值--------------------
SELECT
last_name,
commission_pct
FROM
employees
WHERE
commission_pct IS NULL;
-- ---------------------------查询有奖金的--------------------------------
SELECT
last_name,
commission_pct
FROM
employees
WHERE
commission_pct IS NOT NULL;
-- -----------不能这样使用,is 和 null 不可分割 ↓------------
-- SELECT
-- last_name,
-- commission_pct
-- FROM
-- employees
-- WHERE
-- salary IS 12000;
#安全等于 <=>
SELECT
last_name,
commission_pct
FROM
employees
WHERE
commission_pct <=> NULL; SELECT
last_name,
commission_pct
FROM
employees
WHERE
salary <=> 12000;
IS NULL pk <=>
#查询员工号为176的员工的姓名和部门号,年薪
SELECT
last_name,
department_id,
salary*12*(1+IFNULL(commission_pct,0)) AS 年薪水
FROM
employees
WHERE
employee_id =176;
试问:
SELECT * FROM employees;
和
SELECT * FROM employees WHERE commission_pct LIKE '%%' AND last_name LIKE '%%';
结果是否一样?
不一样,如果判断字段有null值,空。那么结果就不一样
%表示任意多的字符,不能表示null
如果换成or 判断所有字段结果就一样
MySQL条件查询的更多相关文章
- mysql条件查询and or使用实例及优先级介绍
mysql and与or介绍 AND 和 OR 可在 WHERE 子语句中把两个或多个条件结合起来. 使用OR关键字时: 只要符合这几个查询条件的其中一个条件,这样的记录就会被查询出来. 如果不符合这 ...
- (四)MySQL条件查询(通配符、模糊查询)、排序查询、分组查询(单行、分组函数)
一.条件查询 1.含义:前面学的基础查询可以查询一个或多个字段,如果需要的数据仅仅是其中的某一行或多行就用到了条件查询. 2.语法:(序号表示语句执行顺序) SELECT 字段名 ③ FROM 表名 ...
- mysql条件查询中AND与OR联合使用的注意事项!
mysql查询中经常会用到AND与OR一起使用的情况,可如果写法不对,往往会起到相反的效果,这不,前几天就碰到了,最后测试果然提了一堆bug!!!! 废话就不多说了,主要总结一下几点: 一 当mysq ...
- MySQL 条件查询
查询条件 having having的功能和where一样,都是用来筛选查询,不同的是,where在分组之前用,having必须在分组之后使用. # 查询每个部门大于30岁的平均工资,并且保留平均工资 ...
- 三:mysql条件查询
1:查询工资等于5000的员工
- mysql条件查询-排除null ---oracle、mysql 区分总结
' AND IFNULL(c.`COURSE_NO`,'-1') != '-1' ;
- Mysql动态多条件查询
动态多条件查询是一类经常遇到的问题. 在Mysql里面可以用语句简单的解决. SELECT * FROM product WHERE price = IF('{0}' = '', price, '{0 ...
- mysql进阶(五)数据表中带OR的多条件查询
MySQL数据表中带OR的多条件查询 OR关键字可以联合多个条件进行查询.使用OR关键字时: 条件 1) 只要符合这几个查询条件的其中一个条件,这样的记录就会被查询出来. 2) 如果不符合这些查询条件 ...
- Mysql 中Left/Right join on后面and和where条件查询的差异-Mysql SQL运算符是有优先级
一.Mysql中Left/Right join on后面and和where条件查询的差异 1.建两张测试表,一张商户定义表.一张商户操作状态明细表 1)商户定义表 CREATE TABLE hope. ...
随机推荐
- Missing artifact com.oracle:ojdbc14:jar:10.2.0.1.0
问题说明:导入Maven项目时,想要添加Oracle驱动包时,Maven的pom.xml总是报Missing artifact com.oracle:ojdbc14:jar:10.2.0.1.0错. ...
- Sikerio --《只狼》
“狼啊,替我断绝不死吧”
- C#加密与解密(DES\RSA)学习笔记
本笔记摘抄自:https://www.cnblogs.com/skylaugh/archive/2011/07/12/2103572.html,记录一下学习过程以备后续查用. 数据加密技术是网络中最基 ...
- iframe刷新另一个iframe
如果是程序: Response.Write("<script language=javascript>"); Response.Write ...
- ovs安装教程
原文链接:https://www.cnblogs.com/goldsunshine/p/10331606.html Open vSwitch系列之二 安装指定版本ovs Open vSwitch系 ...
- Linux connect: Network is unreachable
在虚拟机中ping,发现网络不通: [root@node01 ~]# ping 114.114.114.114 connect: Network is unreachable 发生此问题时,环境如下: ...
- 小白月赛22 D : 收集纸片
D:收集纸片 考察点 : 全排列,对数据范围的估计程度 坑点 : 注意算最后回到初始的那步距离 析题得侃 : 一看题目最短路,诶呦,这不是最拿手的 BFS 走最短路吗?哈哈,定睛一看 这么多目的地,这 ...
- k8s获取apiversion下面的对应可用资源
1- 获取api命令 [注:以下命令的url地址http://127.0.0.1/为k8s master的地址] kubectl api-versions 输出内容如下: apps/v1beta1 a ...
- 自定义Keras Layer
Keras的Layer其实就是一个Class, 要具有以下几个方法: (1) build(input_shape): 定义权重的地方, 如果不需要定义权重, 也要有self.built = True; ...
- Laravel中使用QRcode自制二维码
一.配置 1.在项目根目录输入命令 composer require simplesoftwareio/simple-qrcode 1.3.* 2.在config/app.php 的 provider ...