博客
关于我
mysql基础教程二
阅读量:794 次
发布时间:2023-02-12

本文共 1770 字,大约阅读时间需要 5 分钟。

进阶2:条件查询

语法与分类

查询语法格式

SELECT 查询列表

FROM 表名
WHERE 筛选条件;

分类

一、按条件表达式筛选

简单条件运算符:> < = != < > >= <=

二、按逻辑表达式筛选

逻辑运算符:用于连接条件表达式

& & & || !
AND、OR、NOT

  • AND:两个条件都为true,结果为true,反之为false
  • OR:只要有一个条件为true,结果为true,反之为false
  • NOT:如果连接的条件本身为false,结果为true,反之为false

三、模糊查询

  • LIKE:用于模糊匹配
  • BETWEEN AND:用于范围查询
  • IN:用于集合判断
  • IS NULL/IS NOT NULL:用于判断NULL值

按条件表达式筛选

案例1:查询工资大于12000的员工信息

SELECT * FROM employees WHERE salary > 12000;

案例2:查询部门编号不等于90号的员工名和部门编号

SELECT last_name, department_id FROM employees WHERE 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;

模糊查询

LIKE

特点:

  • 通常与通配符搭配使用
  • 通配符:%(任意多个字符,包含0个字符)
  • _(任意单个字符)

案例1:查询员工名中包含字符a的员工信息SELECT * FROM employees WHERE last_name LIKE '%a%';

案例2:查询员工名中第三个字符为e,第五个字符为a的员工名和工资SELECT last_name, salary FROM employees WHERE last_name LIKE '_n_a%';

案例3:查询员工名中第二个字符为_的员工名SELECT last_name FROM employees WHERE last_name LIKE '$%' ESCAPE '$';

BETWEEN AND

特点:

  • 使用BETWEEN AND可以提高语句的简洁度
  • 包含临界值
  • 两个临界值不要调换顺序

案例:查询员工编号在100到120之间的员工信息SELECT * FROM employees WHERE employee_id BETWEEN 100 AND 120;

IN

特点:

  • 使用IN可以提高语句简洁度
  • IN列表的值类型必须一致或兼容
  • IN列表中不支持通配符

案例:查询员工的工种编号是IT_PROG、AD_VP、AD_PRES中的一个员工名和工种编号SELECT last_name, job_id FROM employees WHERE job_id IN ('IT_PROT', 'AD_VP', 'AD_PRES');

IS NULL/IS NOT NULL

特点:

  • =或<>不能用于判断NULL值
  • IS NULL或IS NOT NULL可以判断NULL值

案例1:查询没有奖金的员工名和奖金率SELECT last_name, commission_pct FROM employees WHERE commission_pct IS NULL;

案例2:查询有奖金的员工名和奖金率SELECT last_name, commission_pct FROM employees WHERE commission_pct IS NOT NULL;

案例3:查询工资为12000的员工信息SELECT last_name, salary FROM employees WHERE salary <=> 12000;

转载地址:http://ehbfk.baihongyu.com/

你可能感兴趣的文章
mysql的全文检索的方法
查看>>
MySQL的函数
查看>>
mysql的函数DATE_ADD()
查看>>
mysql的函数操作
查看>>
mysql的分类排名_mysql高低排名
查看>>
Mysql的分表设计方法 (水平分表和垂直分表)
查看>>
mysql的分页查询limit关键字
查看>>
MySql的创建数据表、约束、外键约束的创建修改删除、级联操作
查看>>
MySQL的删除修改的实验目的_基础篇 - 数据库及表的修改和删除
查看>>
MySQL的四大隔离级别,你都知道哪些?
查看>>
MySQL的四种事务隔离级别
查看>>
MySQL的基本命令
查看>>
Mysql的备份与恢复类型
查看>>
mysql的大小写对性能的影响问题
查看>>
mysql的密码管理、mysql初始密码查找、密码修改、mysql登录
查看>>
mysql的常见八股文面试题
查看>>
MySQL的常见命令
查看>>
mysql的引擎以及优缺点_MySQL有哪些存储引擎,各自的优缺点,应用场景-阿里云开发者社区...
查看>>
MySQL的操作:
查看>>
mysql的数据类型有哪些?
查看>>