select [distint]* 字段列表 from 表名列表 where 条件列表 group by 分组字段 having 分组之后的条件 order by 排序 limit 分页限定
select * from emp;
1.查询多个列(控制列)
select 字段名1,字段名2… from 表名;
查询所有列
select * from emp; -- 如果查询所有字段,则可以使用*来替代字段列表。
select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp; -- 推荐使用第二种。列出所有列名
一般可以使用四则运算计算一些列的值。(一般只会进行数值型的计算)
select empno,ename,sal,sal*12 from emp;
empno ename sal sal*12
7369 SMITH 800 9600
起别名:as
select ename as "姓名",job as "工作" from emp;
-- as也可以省略
select ename "姓名",job "工作" from emp;
select ename 姓名 ,job 工作 from emp;
select ename "from" ,job 工作 from emp; -- 不推荐
去除重复:distinct
select distinct job as 工作,deptno as 部门编号 from emp ;
① a.null参与运算时,结果永远为null
select ename,sal,comm,sal*12+comm from emp;
oracle的解决方案 --> 使用 nvl (相当于if)
select ename,sal,comm,sal*12+nvl(comm,0) from emp;
额外:nvl2 (if…else…)
nvl2(a,b,c) 当a=null时候,返回c;否则返回b
select ename,sal,comm,sal*12+nvl2(comm,comm,0) from emp;
mysql的解决方案
ifnull(表达式1,表达式2):
关系运算符 > < >= <= = !=(或<>)
如果是null,则使用is null或is not null.
② b. 判断null 不能 !=null;而必须使用 is not null /is null
select * from emp where comm=null;
-- 错误
select * from emp where comm < 400 or comm IS NULL;
mysql 中的逻辑运算符 and(或 &&) or(或 ||) not(或 !)
oracle 逻辑运算符 or and not
select * from emp where empno=7788 or empno=7369;
select * from emp where deptno=20 and job ='CLERK';
select * from emp where not ( empno=7788 or empno=7369 );
而 || 被oracle用于字符串拼接
- select 'hello'||'123' from dual ;
between 小 and 大,(数字和日期)
数字
select * from emp where sal between 2000 and 3000
日期
oracle:日期默认格式 '01-1月-81'(date)
select * from emp where hiredate between '01-1月-81' and '10-11月-81' ;
mysql:日期默认格式 'yyyy-MM-dd'(datetime)
select * from emp where hiredate between '1981-1-01' and '1981-11-10';
select * from emp where comm in (0,300,500);
如果集合有null,可以in, 不能not in
错误示例: where deptno not in (10,20,null)
占位符(通配符)
_
:单个任意字符
%
:多个任意字符 0-N
查询姓名中 第二个字母是M的员工
select * from emp where ename like '_M%' ;
查询姓名长度>=6的员工。
select * from emp where ename like '______%' ;
转义符:
如果要匹配的ename就是A_B
,就需要使用转义符
select * from emp where ename like 'A\_B' escape '\' ;
order by 排序字段1 排序方式1, 排序字段2 排序方式2
排序字段可以是 字段名|别名|表达式|数字
排序方式:
ASC:升序,默认的。
DESC:降序。
如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件。
select * from emp ORDER BY comm asc;
在MySQL中 null最小,升序时 排在最前面
在Oracle中 null最大,升序时 排在最后面
如果排序存在null:在Oracle中Null最大。如果需要null排在最后,使用nulls last ;
…order by common nulls last;
Oracle/Sql Server :从1开始数
MySql:从0开始数
group by 分组字段 having 筛选组
分组之后查询的字段:分组字段、聚合函数
查询时,不在组函数(多行函数)中的列,必须在group by后面
不能在where中使用组函数;可以在having中使用组函数(多行函数)
查询每个部门的人数:按部门分组
- select deptno, job,count(*) from emp group by deptno,job ;
查询每个部门的人数,只查询人数大于5的组
- select deptno,count(*) from emp group by deptno having count(*)>5 ;
可多个列分组(先按部门分组,再按job分组)
select deptno,job,avg(sal) from emp group by deptno,job;
分析:
select 分组1,分组2 ,组函数() from emp group by 分组1,分组2 ;
手机扫一扫
移动阅读更方便
你可能感兴趣的文章