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. ...
随机推荐
- MySQL 8 服务端帮助支持
MySQL 服务器支持 HELP 语句,该语句返回参考手册中相应信息,比如: mysql> help change master to; 返回创建主从复制相关语句的信息 参考手册的信息存储在my ...
- Redis入门-02-CentOS7环境搭建
CentOS7下redis安装过程,安装后需要开启端口号6379 #下载 wget http://download.redis.io/releases/redis-3.2.4.tar.gz #解压 t ...
- STL-list 链表
#include <iostream> #include <list> using namespace std; int main() { // list可以在头部和尾部插入和 ...
- 我用 Python 集齐了五福
[新智元导读]又到了每年集五福的时间.你的五福集齐了吗?每天在各种群里苦苦求扫福,或者忍受着别人天天求扫福,是不是有点厌倦了.作为技术人员,怎么能忍受得了这种低效的全人工操作呢?今天就为大家推荐用 ...
- springboot+druid+mybatis plus的多数据源配置
思路 yml中配置多个数据源信息 通过AOP切换不同数据源 配合mybatis plus使用 POM依赖 <dependency> <groupId>org.springfra ...
- Android中的内存管理机制以及正确的使用方式
概述 从操作系统的角度来说,内存就是一块数据存储区域,属于可被操作系统调度的资源.现代多任务(进程)的操作系统中,内存管理尤为重要,操作系统需要为每一个进程合理的分配内存资源,所以可以从两方面来理解操 ...
- Babel 7 主要改变
1.不支持Node:0.10,0.12,4,5版本 2.更换命名-@babel/xxx 3.移除以年份命名的presets,统一更换成@babel/preset-env 4.移除 ’Stage‘ pr ...
- python之爬虫(爬取.ts文件并将其合并为.MP4文件——以及一些异常的注意事项)
//20200115 最近在看“咱们裸熊——we bears”第一季和第三季都看完了,单单就第二季死活找不到,只有腾讯有资源,但是要vip……而且还是国语版……所以就瞄上了一个视频网站——可以在线观看 ...
- 项目打jar包和运行
打包成jar包和部署,运行. 1.在pom.xml中加入 <packaging>jar</packaging> <groupId>com.demo02</g ...
- Gin_中间件
gin可以构建中间件,但它只对注册过的路由函数起作用 对于分组路由,嵌套使用中间件,可以限定中间件的作用范围 中间件分为全局中间件,单个路由中间件和群组中间件 gin中间件必须是一个 gin.Hand ...