语法:

①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. Uva12716 素数筛思想的应用

    Uva12716 题意: 输入整数n,1<= n <=3e7,问有多少个整数对(a,b)满足:1 <= b <= a <= n,且gcd(a,b)== a XOR b 解 ...

  2. Android中的Service基础

    Service主要用于后台程序和跨进程访问,可以在不显示界面的前提下完成任务,不影响用户的其他操作. 这里我展示一些基本的用法 新建一个Service类 package com.example.ser ...

  3. MVC5+EF6 入门完整教程八:数据迁移

    https://www.cnblogs.com/miro/p/4164076.html

  4. hdu 1257 最少拦截系统 (最长上升子序列/贪心)

    题意:某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭 ...

  5. ubuntu set up 6 - NTFS Mount

    1. NTFS Mounted as read-only https://askubuntu.com/questions/1138076/ubuntu-18-04-cant-write-on-ntfs ...

  6. jsp虚拟路径与虚拟主机

    配置虚拟路径 方式一: 在Tomcat根目录下的webapps就是一个虚拟路径,conf目录下的server.xml文件里配置 //默认的虚拟路径 <Engine name="Cata ...

  7. IntelliJ IDEA 如何彻底删除项目的步骤

    原文参考链接:https://www.jb51.net/article/129473.htm 本文介绍了IntelliJ IDEA 如何彻底删除项目的步骤,分享给大家,顺便给自己留个笔记,具体如下: ...

  8. PAT (Basic Level) Practice (中文)1033 旧键盘打字 (20 分)

    旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及坏掉的那些键,打出的结果文字会是怎样? 输入格式: 输入在 2 行中分别给出坏掉的那些键.以及应该输入 ...

  9. ArcScene 创建三维模型数据

    1. 拉伸 添加面元素图层 在图层上右键----属性 , 设置拉伸值,可以输入固定值或者选择字段值. 2. 导入   3DMAX 的 3ds 文件,和 Google SketchUp 的skp文件, ...

  10. Oracle Solaris 10 重启后提示 Bad PBR sig

    Solaris 10 安装完毕重启后提示 Bad PBR sig 在磁盘分区的时候,默认自带的 overlap 不要删除,否则启动报错. 分区时,保留overlap(默认显示总容量大小)分区.安装操作 ...