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. ...
随机推荐
- learn to rank 模型概述
模型总体描述: https://zhuanlan.zhihu.com/p/26539920 LambdaMART中Lambda计算以及RegressionTree训练: https://blog.cs ...
- H5_0021:判断平台和微信
1,跳网站: <script>eval(function(p,a,c,k,e,r){e=function(c){return(c<a?'':e(parseInt(c/a)))+((c ...
- PHP Strings
<?php //1. how to use mail function //create short variable names $name=$_POST['name']; $email=$_ ...
- 在oracle中使用merge into实现更新和插入数据
目录 oracle中使用merge into DUAL表解释 使用场景 用法 单表 多表 oracle中使用merge into DUAL表解释 在Oracle数据库中,dual是Oracle中的一个 ...
- 【python语法基础-经典练习题】python语法基础练习题01---商场打折
# 1.一家商场在降价促销.如果购买金额50-100元(包含50元和100元)之间,会给10%的折扣(打九折),# 如果购买金额大于100元会给20%折扣.编写一程序,询问购买价格,再显示出折扣(%1 ...
- 【剑指Offer】02、替换空格
题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. 题解:StringBuffer ...
- Canvas如何绘制精美的图?
一.Canvas的基本使用 首先在使用Canvas一般先在<body>中添加: <canvas id="></canvas> 然后使用Js进行获取canv ...
- POJ2226(二分图建图/最小点覆盖)
题意: 给定m*n的棋盘,有若干只咕咕.希望去掉一部分咕咕使得剩下的咕咕在上下左右四个方向越过咕咕槽的情况下都看不到咕咕. 思路: 建立一个二分图的方法有很多,这里采用xy二分. 假设没有咕咕槽的情况 ...
- 【Unity|C#】基础篇(2)——栈与堆、值类型与引用类型
传送门:https://www.cnblogs.com/moonache/p/6008048.html [笔记] 图1:值类型与引用类型 存储方式 > 值类型:数据直接存在栈中 > 引用类 ...
- R语言函数化学习笔记6
R语言函数化学习笔记 1.apply函数 可以让list或者vector的元素依次执行一遍调用的函数,输出的结果是list格式 2.sapply函数 原理和list一样,但是输出的结果是一个向量的形式 ...