数据表
链接:https://pan.baidu.com/s/1dPitBSxLznogqsbfwmih2Q
提取码:b0rp
--来自百度网盘超级会员V5的分享
sql的执行顺序

根据顺序 也就是说 select后面的字段别名 只能在order by中使用
mysql不支持sql92的外连接
mysql不支持满外连接 可以用union补上
去重关键字:DISTINCT

用在单列上是对一列数据去重

用在双列或以上 是对DISTINCT后面这一组数据去重

关于列参与运算问题,数字可以直接参与运算,无论是int或者varchar(只要是数字), 时间类型参与运算自己看情况,null指无法参与运算
可以使用IFNULL(column,0) 来转换




关于着重号 就是 `` 还有特殊用用途,就是当字段是sql保留字或者特殊字的时候
比如下面有张表取名是order 这个和排序时候的order by里的order 属于特殊字
如果直接用 select * from order去查询就报错了


如果在表里有个order字段


需要用着重号 ``

查询常数
查询时候可以加个表里没有的列进行查询

显示表结构
DESCRIBE employees
desc employees

where过滤查询数据

Mysql语法不严谨

练习题:
查询员工12个月的工资总和,并起别名年薪

注意 如果要求取名 A B 中间有个空格的情况下 那么必须加单引号或者双引号或者着重号

查询employees表中对job_id去重

查询工资大于12000的员工姓名和工资

查询员工号为176的员工的姓名和部门号

显示表 departments的结构,并查询其中的全部数据

运算问题
Mysql中的 + - * / div %取余(取模) mod
dual可以看作mysql中的伪表 即使100/2 得到结果是50.0000 只要是除法都会保留4位小数
注意:如果100/0 就是说100 div 0 或者100 mod 0 结果都是null 可以理解为0不能做除数


取余 % 或者 mod和取余(取模)一个意思

如果与字符串数字相加

如果与字符串不是数字相加


有null参与运算就是null

练习:查询员工id为偶数的员工信息 员工id%2=0

比较运算符
等于= 安全等于 <=> 不等于<>或者!= 小于< 小于等于<= 大于> 大于等于>=
比较结果为true 返回 1 比较结果为false 返回0 其他情况返回null

下面来理解 为什么查询时候要查询null的时候 需要用xxx is null 而不能用 xxx=null



关于安全等于 <=>
解释:安全等于(<=>)和等于(=)作用是相似的,唯一区别是'<=>'除了'='功能外还可以用来对null进行判断
用=比较 会出现1 0 null 三种情况 而用<=>比较 会出现 1 或者 0


练习:查询employees表中 commission_pct为null的数据有哪些
那么可查为null 可以使用关键字 is null 也可以使用运算符 <=>


运算符中的一些关键字
is null 为空运算符 判断值,字符串或者表达式是否为空
is not null 不为空运算符 判断值,字符串或者表达式是否不为空
isnull 为空运算符 判断一个值,字符串或者表达式是否为空
--------------------------------------------------------------------------------------------------------------------
least 最小值运算符 在多个值中返回最小值
greatest 最大值运算符 在多个值中返回最大值
-----------------------------------------------------------------------------------------------------------------------
between xxx and xxx 两值之间的运算符 判断一个值是否在两个值之间
--------------------------------------------------------------------------------------------------------------------
in 属于运算符 判断一个值是否为列表中的任意一个值
not in 不属于运算符 判断一个值是否不是一个列表中的任意一直个
-------------------------------------------------------------------------------------------------------------------
like 模糊匹配运算符 判断一个值是否符合模糊匹配规则
-----------------------------------------------------------------------------------------------------------------------
regexp 正则表达式运算符 判断一个值是否符合正则表达式的规则
rlike 正则表达式运算符 判断一个值是否符合正则表达式的规则
关于
is null 为空运算符 判断值,字符串或者表达式是否为空
is not null 不为空运算符 判断值,字符串或者表达式是否不为空
isnull 为空运算符 判断一个值,字符串或者表达式是否为空
的演示

和 is not null相同的一种变态写法

关于
least 最小值运算符 在多个值中返回最小值
greatest 最大值运算符 在多个值中返回最大值
的演示

看看就好 无意义

关于
between xxx and xxx 两值之间的运算符 判断一个值是否在两个值之间 包含边界
演示
注意:使用between 条件1 and 条件2 要求条件1是下线 条件2是上线

反过来 查询工资不在6000到8000之间的呢

not between xxx and xxx

关于
in 属于运算符 判断一个值是否为列表中的任意一个值
not in 不属于运算符 判断一个值是否不是一个列表中的任意一直个
的演示
int(里面放着一个set) not int(里面放着一个set)

注意:为什么这样写是错误的 这是错误演示

not in

关于
like 模糊匹配运算符 判断一个值是否符合模糊匹配规则
的演示

练习:查询表中包含字符'a'且包含字符'e'的员工信息

模糊查询存在一些特殊情况

比如我需要查询第二个字符是'_'并且第三个字符是'a'的

用转义字符:\

转义字符的特殊用法 ESCAPE的用法


关于
regexp 正则表达式运算符 判断一个值是否符合正则表达式的规则
rlike 正则表达式运算符 判断一个值是否符合正则表达式的规则
的演示
^ 开头
& 结尾

逻辑运算符:
逻辑运算符主要用来判断表达式的真假,在Mysql中,逻辑运算符的返回结果为 1(true) 0(false) 或者null
not 或 ! 逻辑非
and 或 && 逻辑与
or 或 || 逻辑或
xor 逻辑异或
and的优先级高于or
关于XOR 就是满足一个条件但是不满足另外的条件

SELECT * FROM your_table WHERE condition1 XOR condition2 XOR condition3;
就是满足其中一个条件 但是不能同事满足其他条件
比较运算符和逻辑运算符练习
查询工资不在5000到12000的员工的姓名和工资

查询在20或50号部门工作的员工姓名和部门号

查询公司中没有管理者的员工姓名及job_id

查询公司中有奖金的员工姓名,工资和奖金级别

查询员工姓名的第三个字母是a的员工姓名

查询姓名中有字母a和k的员工姓名

查询员工表中 first_name以 'e' 结尾的员工信息

查询员工表中部门编号在80到100之间的姓名,工种

查询员工表中manager_id是 100,101,110的员工姓名,工资,管理者id

第5章 排序与分页
asc 升序 默认
desc 降序
没有使用排序 例如
select * from employees 排序规则是数据库表数据 实际添加的先后顺序



使用别名进行排序

select查询语句的执行顺序

为什么只有order by中才可以使用别名 原因 select 选择要显示的列 在order by执行之前
# 注意 根据sql查询的顺序 列的别名只能在order by中使用 where中使用会报错
Limit 分页

显示第二页面20条数据
这里有个公式
pageNo:表示页数
pageSize:表示显示条数
limit (pageNo-1)*pageSize,pageSize
那么显示第二页20条数据就是
limit (2-1)*20,20 注意MYSQL不支持这样写 实际项目中 计算好


limit 0,20 可以简写成 limit 20
where ..... order by.... limit ...
练习:员工表一共107条数据 但是我只想显示第 32,33条数据
limit 参数1,参数2 参数1 意思跳过前面多少条数据 参数2 显示后面多少条数据
那么 limit 31,2 跳过前面31条数据 显示两条 那么不就是 32 和 33条数据么

LIMIT在Mysql8z之后新特性
LIMIT ....OFFSET..... 其实就是原先的参数换个位置

LIMIT 放在查询语句最后
练习:查询员工表中工资最高的员工信息

注意:
不同数据库分页不同

LIMIT可以在Mysql,PGSQL,MARIADB,SQLite等数据库中使用,表示分页
不能使用在SQLServer DB2 Oracle中
Oracle中实现分页的一种方式: 通过rownum
SELECT *
FROM (
SELECT
my_table.*,
ROWNUM AS row_num
FROM my_table
WHERE ROWNUM <= page * size
)
WHERE row_num > ((page-1) * size);
排序与分页练习
查询员工的姓名和部门号和年薪,按照年薪降序,如果年薪相同按姓名升序显示

当然 asc可以不写

不然引号可以


查询工资不在8000到17000的员工的姓名和工资,按工资降序,显示第21到40位置的数据

查询邮箱中包含e的员工信息,并先按邮箱的字节数降序,再按部门号升序

第六章:关联表查询


比如查询员工 'Abel'在哪个城市工作



如果这样查 数据库连接要3次
那么关联表查询目的就是一次查出来
演示笛卡尔积








多表联查:需要有连接条件 这里是sql92的写法
多表联查前提条件是这些一起查询的表之间是有关系的(1对1,1对多)

注意 当两张表中有重名字段时候 前面需要加表名


可以给别起别名

练习:查询员工的编号,姓名,部门名字,所在城市

多表联查分类
1.关于等值连接和非等值连接(针对连接条件来讲)
2.自连接和非自连接
3.内连接和外连接

1.关于等值连接和非等值连接(针对连接条件来讲)
查询每个员工的薪资等级

2.自连接和非自连接
练习:查询员工id,员工姓名,和上级领导id和上级领导的姓名

3.内连接和外连接 sql92与sql99语法如何实现内连接与外连接
内连接:上面的关联表查询都是内连接
外连接


SQL99语法


left join和left out join 一个意思
左外连接 107条数据


右外连接 right join .... on

满外连接 意思满足左边的表也满足右表 Mysql不支持 Oracle支持

SQL99中 7种JOIN的实现

在Mysql中实现
通过UNION关键字合并
要求:两个表对应的列数和数据类型必须相同,并且互相对应

UNION和UNION ALL区别
UNION会去重
UNION ALL 不会去重
那么在Mysql中想实现满外连接
用左外连接加右外连接 通过 UNION就可以实现
Mysql中要实现满外连接

UNION和UNION ALL的使用
因为UNION ALL不需要去重 相对效率高


说错了 右外连接 有些部门里没有员工


其实条件本身为null用a.department_id或者b.department_id都一样





SQL99语法新特性
自然连接 NATURAL JOIN 和 USING连接
NATURAL JOIN用来表示自然连接.可以把自然连接理解为SQL92中的等值连接.它会对两张表中所有相同的字段,然后进行等值连接
也就是说只要字段名相同 默认他们为连接条件
注意:NATURAL JOIN 自然连接 好比INNER JOIN


USING连接 指定连接条件的字段

拓张:使用join...on还可以这么使用


多表联查练习:
查询所有员工的姓名,部门号和部门名称

查询90号部门员工的job_id和90号部门的location_id

查询所有有奖金的员工的last_name,job_id,department_id,department_name
where a.commission_pct is not null 注意这里要用left join 原因:所有员工

查询city在Toronto工作的员工的last_name,job_id,department_id,department_name

查询员工所在部门名称,部门地址,姓名,工作,工资其中员工所在部门名称为'Executive'

查询指定员工姓名,员工号,以及他的管理者的姓名和员工号,结果类似于下面的格式
employess EMP# manager Mgr#
kochhar 101 King 100

查询哪些部门没有员工

NOT EXISTS

查询哪个城市没有部门

查询部门名为Sales或者IT的员工信息

第七章:函数的分类
1.单行函数(内置函数) 一行数据出来一个结果
2.多行函数(聚合函数)(内置函数) 多行数据出来一个结果
3.自定义函数
单行函数:大致分类
数值类型函数
字符串类型函数
日期时间类型函数
流程控制函数
加解密信息函数
链接:https://pan.baidu.com/s/1-dPWDIXX02XTLeyhb1ZZuQ
提取码:z2jg
--来自百度网盘超级会员V5的分享