博客
关于我
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 5.0-触发器(参考)_mysql
查看>>
MySQL及navicat for mysql中文乱码
查看>>
MySqL双机热备份(二)--MysqL主-主复制实现
查看>>
MySql各种查询
查看>>
mysql启动以后会自动关闭_驾照虽然是C1,一直是开自动挡的车,会不会以后就不会开手动了?...
查看>>
mysql启动和关闭外键约束的方法(FOREIGN_KEY_CHECKS)
查看>>
Mysql启动失败解决过程
查看>>
MySQL启动失败:Can't start server: Bind on TCP/IP port
查看>>
mysql启动报错
查看>>
mysql启动报错The server quit without updating PID file几种解决办法
查看>>
MySQL命令行登陆,远程登陆MySQL
查看>>
mysql命令:set sql_log_bin=on/off
查看>>
MySQL和Java数据类型对应
查看>>
mysql和oorcale日期区间查询【含左右区间问题】
查看>>
MySQL和SQL入门
查看>>
mysql在centos下用命令批量导入报错_Variable ‘character_set_client‘ can‘t be set to the value of ‘---linux工作笔记042
查看>>
Mysql在Linux运行时新增配置文件提示:World-wrirable config file ‘/etc/mysql/conf.d/my.cnf‘ is ignored 权限过高导致
查看>>
Mysql在Windows上离线安装与配置
查看>>
MySQL在渗透测试中的应用
查看>>
Mysql在离线安装时启动失败:mysql服务无法启动,服务没有报告任何错误
查看>>