博客
关于我
mysql基础教程二
阅读量:790 次
发布时间: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学习总结(51)——Linux主机Mysql数据库自动备份
查看>>
Mysql学习总结(52)——最全面的MySQL 索引详解
查看>>
Mysql学习总结(53)——使用MySql开发的Java开发者规范
查看>>
Mysql学习总结(54)——MySQL 集群常用的几种高可用架构方案
查看>>
Mysql学习总结(55)——MySQL 语句大全再温习
查看>>
Mysql学习总结(56)——MySQL用户管理和权限设置
查看>>
Mysql学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
查看>>
Mysql学习总结(63)——Mysql数据库架构方案选择与分析
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(67)——MYSQL慢查询日志
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>