【竺】数据库笔记1
学习MySQL主要还是学习通用的SQL语句,那么SQL语句包括增删改查,SQL语句怎么分类呢?
DQL(数据查询语言): 查询语句,凡是select语句都是DQL。
DML(数据操作语言):insert delete update,对表当中的数据进行增删改。
DDL(数据定义语言):create drop alter,对表结构的增删改。
TCL(事务控制语言):commit提交事务,rollback回滚事务。(TCL中的T是Transaction)
DCL(数据控制语言): grant授权、revoke撤销权限等。
一、DDL数据定义语言
1、连接数据库
cmd-》mysql -uroot -p123456
2、创建数据库
create database bj;
3、查看有哪些数据库
show databases;
4、使用bj数据库
use bj;
5、查看当前使用的数据库中有哪些表
show tables;
6、导入数据
source D:\bj.sql
7、查看表结构
desc dept;
desc emp;
desc salgrede;
8、查看表中的数据
select * from emp;
8、删除数据库
drop database bj;
9、命令行外查看数据库版本
mysql --version
mysql -P
10、查看当前使用的是哪个数据库
select database();
11、查看mysql版本
select version();
12、离开mysql
exit
二、简单查询语句(DQL)
1、简单的查询语句,查询员工的年薪?
select ename,sal * 12 as '年薪' from emp;
三、条件查询
1、查询工资等于5000的员工姓名?
select ename from emp where sal = 5000;
2、查询SMITH的工资?
select sal from emp where ename = 'SMITH'; // 字符串使用单引号括起来。
3、找出工资高于3000的员工?
select ename,sal from emp where sal > 3000;
4、找出工资不等于3000的?
select ename,sal from emp where sal <> 3000;
select ename,sal from emp where sal != 3000;
5、找出工资在1100和3000之间的员工,包括1100和3000?
select ename,sal from emp where sal >= 1100 and sal <= 3000;
select ename,sal from emp where sal between 1100 and 3000; // between...and...是闭区间 [1100 ~ 3000]
6、找出哪些人津贴为NULL?
在数据库当中NULL不是一个值,代表什么也没有,为空。
必须使用 is null或者is not null
select ename,sal,comm from emp where comm is null
7、找出哪些人没有津贴?
select ename,sal,comm from emp where comm is null or comm = 0;
8、找出工作岗位是MANAGER和SALESMAN的员工?
select ename,job from emp where job = 'MANAGER' or job = 'SALESMAN';
9、and和or联合起来用:找出薪资大于1000的并且部门编号是20或30部门的员工。
select ename,sal,deptno from emp where sal > 1000 and (deptno = 20 or deptno = 30); // 正确的。
注意:当运算符的优先级不确定的时候加小括号。
10、in等同于or:找出工作岗位是MANAGER和SALESMAN的员工?
select ename,job from emp where job in('SALESMAN', 'MANAGER');
select ename,job from emp where sal in(800, 5000); // in后面的值不是区间,是具体的值。
11、not in: 不在这几个值当中。
select ename,job from emp where sal not in(800, 5000);
12、模糊查询like ? 找出名字当中含有O的?
(在模糊查询当中,必须掌握两个特殊的符号,一个是%,一个是_)
%代表任意多个字符,_代表任意1个字符。
select ename from emp where ename like '%O%';
13、找出名字中第二个字母是A的?
select ename from emp where ename like '_A%';
14、找出名字中有下划线的?
select name from t_user where name like '%\_%'; // \转义
15、找出名字中最后一个字母是T的?
select ename from emp where ename like '%T';
四、排序(升序、降序)
1、 按照工资升序,找出员工名和薪资?
注意:默认是升序。怎么指定升序或者降序呢?asc表示升序,desc表示降序。
select ename , sal from emp order by sal; // 升序
select ename , sal from emp order by sal asc; // 升序
select ename , sal from emp order by sal desc; // 降序。
2、按照工资的降序排列,当工资相同的时候再按照名字的升序排列。
select ename,sal from emp order by sal desc;
select ename,sal from emp order by sal desc , ename asc;
注意:越靠前的字段越能起到主导作用。只有当前面的字段无法完成排序的时候,才会启用后面的字段。
3、找出工作岗位是SALESMAN的员工,并且要求按照薪资的降序排列。
select ename,job,sal from emp where job = 'SALESMAN' order by sal desc;
五、分组函数
count 计数
sum 求和
avg 平均值
max 最大值
min 最小值
记住:所有的分组函数都是对“某一组”数据进行操作的。
1、找出工资总和?
select sum(sal) from emp;
2、找出最高工资?
select max(sal) from emp;
3、找出最低工资?
select min(sal) from emp;
4、找出平均工资?
select avg(sal) from emp;
5、找出总人数?
select count(*) from emp;
select count(ename) from emp;
6、找出工资高于平均工资的员工?
select ename,sal from emp where sal > (select avg(sal) from emp);
7、计算每个员工的年薪?
select ename,(sal+comm)*12 as yearsal from emp;
重点:所有数据库都是这样规定的,只要有NULL参与的运算结果一定是NULL。
使用ifnull函数:
select ename,(sal+ifnull(comm,0))*12 as yearsal from emp;
ifnull() 空处理函数?
ifnull(可能为NULL的数据,被当做什么处理) : 属于单行处理函数。
select ename,ifnull(comm,0) as comm from emp;
六、group by 和 having
group by : 按照某个字段或者某些字段进行分组。
having : having是对分组之后的数据进行再次过滤。
1、找出每个工作岗位的最高薪资
select max(sal),job from emp group by job;
2、每个工作岗位的平均薪资?
select job,avg(sal) from emp group by job;
3、找出每个部门不同工作岗位的最高薪资。
select DEPTNO,job,max(sal) from emp group by DEPTNO,job;
4、找出每个部门的最高薪资,要求显示薪资大于2900的数据。
第一步:找出每个部门的最高薪资
select max(sal),deptno from emp group by deptno;
第二步:找出薪资大于2900
select max(sal),deptno from emp group by deptno having max(sal) > 2900; // 这种方式效率低。
select max(sal),deptno from emp where sal > 2900 group by deptno; // 效率较高,建议能够使用where过滤的尽量使用where。
5、要求显示薪资大于2000的数据
select deptno,avg(sal) from emp group by deptno having avg(sal) > 2000;
where后面不能使用分组函数:
select deptno,avg(sal) from emp where avg(sal) > 2000 group by deptno;// 错误了。
这种情况只能使用having过滤。