语法:

①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条件查询的更多相关文章

  1. mysql条件查询and or使用实例及优先级介绍

    mysql and与or介绍 AND 和 OR 可在 WHERE 子语句中把两个或多个条件结合起来. 使用OR关键字时: 只要符合这几个查询条件的其中一个条件,这样的记录就会被查询出来. 如果不符合这 ...

  2. (四)MySQL条件查询(通配符、模糊查询)、排序查询、分组查询(单行、分组函数)

    一.条件查询 1.含义:前面学的基础查询可以查询一个或多个字段,如果需要的数据仅仅是其中的某一行或多行就用到了条件查询. 2.语法:(序号表示语句执行顺序) SELECT 字段名 ③ FROM 表名 ...

  3. mysql条件查询中AND与OR联合使用的注意事项!

    mysql查询中经常会用到AND与OR一起使用的情况,可如果写法不对,往往会起到相反的效果,这不,前几天就碰到了,最后测试果然提了一堆bug!!!! 废话就不多说了,主要总结一下几点: 一 当mysq ...

  4. MySQL 条件查询

    查询条件 having having的功能和where一样,都是用来筛选查询,不同的是,where在分组之前用,having必须在分组之后使用. # 查询每个部门大于30岁的平均工资,并且保留平均工资 ...

  5. 三:mysql条件查询

    1:查询工资等于5000的员工

  6. mysql条件查询-排除null ---oracle、mysql 区分总结

    ' AND IFNULL(c.`COURSE_NO`,'-1') != '-1' ;

  7. Mysql动态多条件查询

    动态多条件查询是一类经常遇到的问题. 在Mysql里面可以用语句简单的解决. SELECT * FROM product WHERE price = IF('{0}' = '', price, '{0 ...

  8. mysql进阶(五)数据表中带OR的多条件查询

    MySQL数据表中带OR的多条件查询 OR关键字可以联合多个条件进行查询.使用OR关键字时: 条件 1) 只要符合这几个查询条件的其中一个条件,这样的记录就会被查询出来. 2) 如果不符合这些查询条件 ...

  9. Mysql 中Left/Right join on后面and和where条件查询的差异-Mysql SQL运算符是有优先级

    一.Mysql中Left/Right join on后面and和where条件查询的差异 1.建两张测试表,一张商户定义表.一张商户操作状态明细表 1)商户定义表 CREATE TABLE hope. ...

随机推荐

  1. MySQL 8 服务端帮助支持

    MySQL 服务器支持 HELP 语句,该语句返回参考手册中相应信息,比如: mysql> help change master to; 返回创建主从复制相关语句的信息 参考手册的信息存储在my ...

  2. Redis入门-02-CentOS7环境搭建

    CentOS7下redis安装过程,安装后需要开启端口号6379 #下载 wget http://download.redis.io/releases/redis-3.2.4.tar.gz #解压 t ...

  3. STL-list 链表

    #include <iostream> #include <list> using namespace std; int main() { // list可以在头部和尾部插入和 ...

  4. 我用 Python 集齐了五福

    ​ [新智元导读]又到了每年集五福的时间.你的五福集齐了吗?每天在各种群里苦苦求扫福,或者忍受着别人天天求扫福,是不是有点厌倦了.作为技术人员,怎么能忍受得了这种低效的全人工操作呢?今天就为大家推荐用 ...

  5. springboot+druid+mybatis plus的多数据源配置

    思路 yml中配置多个数据源信息 通过AOP切换不同数据源 配合mybatis plus使用 POM依赖 <dependency> <groupId>org.springfra ...

  6. Android中的内存管理机制以及正确的使用方式

    概述 从操作系统的角度来说,内存就是一块数据存储区域,属于可被操作系统调度的资源.现代多任务(进程)的操作系统中,内存管理尤为重要,操作系统需要为每一个进程合理的分配内存资源,所以可以从两方面来理解操 ...

  7. Babel 7 主要改变

    1.不支持Node:0.10,0.12,4,5版本 2.更换命名-@babel/xxx 3.移除以年份命名的presets,统一更换成@babel/preset-env 4.移除 ’Stage‘ pr ...

  8. python之爬虫(爬取.ts文件并将其合并为.MP4文件——以及一些异常的注意事项)

    //20200115 最近在看“咱们裸熊——we bears”第一季和第三季都看完了,单单就第二季死活找不到,只有腾讯有资源,但是要vip……而且还是国语版……所以就瞄上了一个视频网站——可以在线观看 ...

  9. 项目打jar包和运行

    打包成jar包和部署,运行. 1.在pom.xml中加入  <packaging>jar</packaging> <groupId>com.demo02</g ...

  10. Gin_中间件

    gin可以构建中间件,但它只对注册过的路由函数起作用 对于分组路由,嵌套使用中间件,可以限定中间件的作用范围 中间件分为全局中间件,单个路由中间件和群组中间件 gin中间件必须是一个 gin.Hand ...