【竺】数据库笔记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过滤。

(0)

相关推荐