select条件查询的格式如下:

SELECT
查询列表
FROM
表名
WHERE
筛选条件;
1
2
3
4
5
6
根据筛选条件可以分为以下几类:

按照条件按表达式进行筛选

常用条件运算符如下:> 、<、=、!=、<>、<=、>=

按照逻辑表达式进行筛选

​ 逻辑运算符的主要作用:用于连接条件表达式

& 、 || 、! 、and、or、not

模糊查询

like、between and 、in、is null

like通常和通配符搭配使用:
①:%:代表任意多个字符

②:_:代表任意单个字符

举个栗子:

/**查询员工工资大于10000的员工信息**/
SELECT * FROM employees WHERE salary > 1000;
/**查询部门标号不等于90号的员工名和部门编号 **/
SELECT name,department_id FROM employees WHERE department_id <> 90;
/**查询工资在1000-2000之间的员工名,工资 **/
SELECT name,salary FROM employees WHERE salary >= 1000 and salary <=2000;
/**查询部门编号不再20-40之间或者工资高于15000员工信息 **/
SELECT * FROM employees WHERE department_id < 20
1
2
3
4
5
6
7
8
like:

/**查询员工名中包含a的员工信息**/
SELECT * FROM employeess WHERE last_name like '%a%';
/**查询员工名中第三个字符为n,第五个字符为m的员工信息 **/
SELECT * FROM employees WHERE last_name like '__n_m%';
/**查询员工名中第二个字符_的员工信息**/
/**方法一:使用转义字符"\"**/
SELECT * FROM employees WHERE last_name like '_\_%';
/**方法二:自定义转义字符**/
SELECT * FROM employees WHERE last_name like '_$_%' ESCAPE '$';
1
2
3
4
5
6
7
8
9
between and 、in

/**查询员工工资在1000-2000之间的员工信息(包含临界值)**/
SELECT * FROM employees WHERE salary BETWEEN 1000 AND 2000;
/**查询员工工种编号为IT_PROG、AD_VP、AD_PRES中的一个员工名和工种编号**/
/**方法一:**/
SELECT job_id,last_name FROM employees
WHERE job_id ='IT_PROG' OR
job_id ='AD_VP' OR
job_id ='AD_PRES' ;
/**方法二:**/
SELECT job_id,last_name FROM employeess
WHERE job_id in ('IT_PROG','AD_VP','AD_PRES');
1
2
3
4
5
6
7
8
9
10
11
in关键字的特点:

判断某字段的值是否属于in列表项中的某一项
in列表中的值都是统一类型或者相互兼容(即可以相互转换)
is null

/**查询员工没有奖金的员工名和奖金率**/
SELECT last_name,commission_pct
FROM employeess
WHERE commission_pct IS NULL;
/**查询员工有奖金的员工名和奖金率**/
SELECT last_name,commission_pct
FROM employeess
WHERE commission_pct IS NOT NULL;
1
2
3
4
5
6
7
8
安全等于 <=>

/**查询员工工资等于10000的员工信息**/
SELECT * FROM employees WHERE salary <=> 1000;
/**查询员工没有奖金的员工名和奖金率**/
SELECT last_name,commission_pct
FROM employeess (http://www.my516.com)
WHERE commission_pct <=> NULL;
1
2
3
4
5
6
正常数值的判断 null判断 可读性
安全等于 <=> 可以判断 可以判断 低
is null 不可以判断 可以判断 高
/**查询员工号为124的员工名和部门号以及年薪**/
SELECT
last_name,
department_id,
slary*12(1+IFNULL(comission_pct,0)) AS 年薪
FROM employees
WHERE department_id = 124;
/**查询employeess表中都涉及到了哪些部门编号**/
SELECT DISTINCT department_id FROM employees ;
1
2
3
4
5
6
7
8
9
思考题:

/**语句1:**/
SELECT * FROM employees;
/**语句2:**/
SELECT * FROM emplooyees
WHERE comission_pct LIKE '%%' AND last_name LIKE'%%';
/**语句3:**/
SELECT * FROM emplooyees
WHERE comission_pct LIKE '%%' OR last_name LIKE'%%';
1
2
3
4
5
6
7
8
问题1:语句1和语句2查询结果是否相同?

> 不相同,如果comission_id为null(即没有没有任何字符)是查询不出来的;
> 当comission_id不可能为null时,两者的查询结果是相同的
1
2
问题2:语句1和语句3查询结果是否相同

> 相同,因为last_name不可能为null值,此时即使comission_id为null也会被查询出来。
---------------------

MySql(四)Select条件查询的更多相关文章

  1. Mysql高手系列 - 第7篇:玩转select条件查询,避免踩坑

    这是Mysql系列第7篇. 环境:mysql5.7.25,cmd命令中进行演示. 电商中:我们想查看某个用户所有的订单,或者想查看某个用户在某个时间段内所有的订单,此时我们需要对订单表数据进行筛选,按 ...

  2. Mysql动态多条件查询

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

  3. 七、玩转select条件查询

    前言: 电商中:我们想查看某个用户所有的订单,或者想查看某个用户在某个时间段内所有的订单,此时我们需要对订单表数据进行筛选,按照用户.时间进行过滤,得到我们期望的结果. 此时我们需要使用条件查询来对指 ...

  4. Mysql数据库中条件查询

    1.concat(字符串拼接) 作用:将选中的列进行拼接  写法 AS的作用就是属性名 SELECT CONCAT(ename,job) AS 你猜 FROM emp; 2.条件查询 语法: sele ...

  5. Eclipse+Mysql实现多条件查询

    最近做一个项目的时候,就需要用到多条件查询,但是一直不完美,所有有bug,不过今天经高人提醒,做出了个小例子,在这里简单跟大家分享一下: 不说多了,直接放关键sql代码: 已知条件:菜名,菜品,价格区 ...

  6. 10. MySQL基础-02条件查询、排序查询

    2. 条件查询 语法 ​ select 查询列表 from 表名 where 筛选条件: 分类 按条件表达式筛选 简单的条件运算符:> < = != <> >= ⇐ 按逻 ...

  7. 【MySQL】SELECT语句 - 查询数据

    第4章 检索数据 文章目录 第4章 检索数据 1.SELECT语句 2.检索单个列 3.检索多个列 4.检索所有列 5.检索不同的行 6.限制结果 7.使用完全限定的表名 8.小结 简单记录 - My ...

  8. MySql 按日期条件查询数据

    本周内: select * from wap_content where week(created_at) = week(now) 查询一天: select * from table where to ...

  9. mysql uodate select子查询

    UPDATE user SET pwd='123' WHERE id in (    SELECT id from user WHERE username = 'zx' ); 报错[Err] 1093 ...

随机推荐

  1. Android之——多线程下载演示样例

    转载请注明出处:http://blog.csdn.net/l1028386804/article/details/46883927 一.概述 说到Android中的文件下载.Android API中明 ...

  2. Cracking the Coding Interview 150题(二)

    3.栈与队列 3.1 描述如何只用一个数组来实现三个栈. 3.2 请设计一个栈,除pop与push方法,还支持min方法,可返回栈元素中的最小值.pop.push和min三个方法的时间复杂度必须为O( ...

  3. nginx-1.5.10 之mips编译到RT5350

    编译nginx-1.5.10一般须要下面库的支持:pcre,zlib,openssl 此次编译nginx-1.5.10使用的库版本号分别为pcre-8.34:openssl-1.0.0l:zlib-1 ...

  4. openstack (3)---------部署memcached缓存服务,keystone服务

    一.memcached概念 Memcached 是一个开源的.高性能的分布式内存对象缓存系统.通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高网站访问速度,加速动态WEB应用.减轻数据库负载 ...

  5. A星算法(Java实现)

    一.适用场景 在一张地图中.绘制从起点移动到终点的最优路径,地图中会有障碍物.必须绕开障碍物. 二.算法思路 1. 回溯法得到路径 (假设有路径)採用"结点与结点的父节点"的关系从 ...

  6. 从零開始学android&lt;Bitmap图形组件.四十七.&gt;

    android.graphics.Bitmap(位图)是Android手机中专门提供的用于操作图片资源的操作类,使用此类能够直接从资源文件之中进行图片资源的读取.而且对这些图片进行一些简单的改动. 经 ...

  7. ios32---线程的状态

    // // ViewController.m // 04-了解-线程的状态 // // 创建线程是处于新建状态,start是就绪状态,会放入到可调度线程池里面(cpu看线程是否可以调用,是看线程是否在 ...

  8. bzoj1898 [Zjoi2005]Swamp 沼泽鳄鱼——矩阵快速幂

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1898 求到达方案数...还是矩阵快速幂: 能够到达就把邻接矩阵那里赋成1,有鳄鱼的地方从各处 ...

  9. 全分布式的Hadoop虚拟机安装

    在集群环境下装机.配置.运行的全过程,梳理总结到本文中. 第一部分:环境规划 •用户 hadoop 密码 hadoop •机器 机器名称 IP地址 Master.Hadoop 192.168.1.10 ...

  10. 从缓冲上看阻塞与非阻塞socket在发送接收上的区别(转载)

    转自:http://blog.chinaunix.net/uid-24517549-id-4044877.html   首先socket在默认情况下是阻塞状态的,这就使得发送以及接收操作处于阻塞的状态 ...