目录
基础查询
语法:
select 查询列表 from 表名;
特点:
1.查询列表可以是:表中的字段、常量值、表达式、函数
2.查询的结果是一个虚拟的表格
1.查询表中的单个字段
select last_name from employees;
2.查询表中的多个字段
select last_name,salary,email from employees;
3.查询表中的多个字段
select * from employees;
4.查询常量值
select 100;
select 'john';
5.查询表达式
select 100%98;
6.查询函数
select version();
7.起别名
好处:1 便于理解
2 区分有重名的情况
方式一:
select 100%98 as 结果;
select last_name as 姓,first_name as 名 from employees;
方式二:
select last_name 姓,first_name 名 from employees;
8.去重distinct
#案例:查询员工表中涉及到的所有的部门编号
select departent_id from employees;
select distinct departent_id from employees;
9. +号的作用
java中+号:
运算符、拼接符
mysql中+号:
仅仅只有一个功能:运算符。
select 100+90;直接做加法190
select ‘100’+90;字符型转换成数值型做加法190
selec ‘john’+90;转换失败则为0;结果为0+90=90
select null+90;只要一个null,则结果为空
10.拼接concat
select concat(last_name,first_name) as 姓名 from employees;
条件查询
语法:
select 查询列表 from 表名 where 筛选条件;
分类:
1.按条件表达式筛选
条件运算符:> < = != >= <= <>
2.按逻辑表达式筛选
&& || !and or not
3.模糊查询
like,between and,in ,is null
1.按按条件表达式筛选
案例1: 查询工资>12000的员工信息
select * from employees where salary>12000;
案例2: 查询部门编号不等于90号的员工名和部门编号
select last_name,department_id from employees where department_id<>90;
2.按逻辑表达式筛选
案例 .查询工资在10000到20000之间的员工名、工资及奖金
select last_name,salary,comission_pct from employees
where salary>=1000 and salary<=2000;
3.模糊查询
like:
通配符: % 任意多个字符,包含0个 。_任意单个字符
转义符: \
自定义转义字符 escape
1.查询员工中包含字符a的员工信息
select * from employees where last_name like '%a%';
2.询员工中第二个字符a为_的员工信息
select * from employees where last_name like '_\_%';
select * from employees where last_name like '_&_%' escape '&';
between and:
select * from employees where employee_id between 80 and 100;
in 、not in 可用于字符查询
select * from employees where Last_name in('aaa','bcd');
is null:
select * from aaa where commission_pct is null;
ifnull:
查询员工号为176的员工姓名、部门号和年薪
select Last_name,department_id,salary*12*(1+ifnull(comission_pct,0)) as 年薪
from employees;
(‘=’不能判断空值‘is’不能做运算符, 安全等于<=>可以判断null,也可判断数值)