发布于2019-08-07 10:07 阅读(1164) 评论(0) 点赞(0) 收藏(3)
注意点
select 指定表.字段 from 表1,表2
四则运算包括加减乘除
select 字段1 四则运行符号 字段2 from 表名称
语法:select 函数(字段1) from 表名称
统计函数
比较运算符 | 介绍 |
---|---|
<,<=,>,>=,=,!= | 小于,小于等于,大于,大于等于,等于,不等于 |
in(set) | 成员运算,看值有没有再列表里面 |
like | 模糊查找:%代表零个或多个字符,_代表一个字符 |
is null | 判断是否为空 |
between A and B | 显示某个区间:A-B 包括A和B |
逻辑运算符 | 介绍 |
and | 且,多个条件同时满足 |
or | 或者,满足多个条件其中一条 |
not | 不成立 |
binary
区分大小写
语法:select 段落 from 表明 where binary 字段....................................
分组
语法
select....from 表名
where .......
group by 字段名称 #如果这里有多个字段,A,B,用,连接表示具有相同字段A以及相同字段B进行分组
having 判断内容
注意:
排序
语法:默认为升序
ord by 字段名称
固定升序或者降序
多个条件排序主次关系
ord by 主字段,次字段
限制显示记录
对于单页表操作
limit start count
对于多页操作
分页原理:先查询总数据条数 设为a
确定每页数量b
总页数为c = a / b 如果除不尽则需要加1 例如 10 / 3 正确页数为4
查询语句的起始位置为s = 当前页数d 减去1 乘以每页数量
即 s = (d - 1) * b
limit s b
语法 :where 字段名称 regexp '正则表达式'
注意:正则表达式不包括特殊字符如\w
语法:select *from 表1,表2
他会把多个表每行与另外个表统统匹配上,其中会有一些脏数据,我们可以用里面值的关系进行连接
其本质就是笛卡尔积查询
区别是把,变成 join
且不能用where,要先用on根据里面值的关系拼接好了再用 where
左表中记录的无论是否有匹配关系都全部显示,右表中仅显示匹配成功的记录
语法:select *from 表1 left join,表2
右表中记录的无论是否有匹配关系都全部显示,左表中仅显示匹配成功的记录
语法:select *from 表1 right join 表2
无论是否匹配成功,两边表中的记录都要全部显示
select *from 表1 full join 表2
注意:mysql 不支持
我们要引入union
union 只能用于字段数量相同的两个表 会自动去除重复的记录
union all 则保留所有记录
select from dept left join emp on dept.id=emp.dept_id
union
select from dept right join emp on dept.id=emp.dept_id;
可以完成全外连接
将查找后的内容作为查找的值或者查找的对象,
如果要作为一个表当作查找对象,要对于查找后的表进行重命名语法如下
select .... from (select ....from .......) as 新名字
"查询平均年龄大于25的部门名称
子查询方式:
平均年龄大于25的部门id有哪些?
先要求出每个部门的平年龄! 筛选出平均年龄大于25的部门id
拿着部门id 去查询部门表查询"
select name from dept where id in (select dept_id from emp group by dept_id having avg(age) > 25);
"多表查询方式:
先把数据拼接到一起 在加以筛选"
select dept.name from emp inner join dept
on emp.dept_id = dept.id
group by dept.name
having avg(age) >25;
xists 后跟子查询 子查询有结果是为True 没有结果时为False
为true时外层执行 为false外层不执行
select *from emp where exists (select *from emp where salary > 1000);
#查看exists 的返回结果: 只有 0 和 1
select (exists (select *from emp where salary > 10000));
#一个查询结果也是一个表 既然是表就能链接起来
#综合练习:
"查询每个部门工资最高的员工信息
先查询每个部门的最高工资
将查询结果与员工表联合起来
在加条件判断部门id相同并且 最高工资相同 则显示"
select *from emp inner join
(select dept_id,max(salary) m from emp group by dept_id) t2
on emp.dept_id = t2.dept_id
where
emp.salary = t2.m;
作者:西红柿煎鸡蛋
链接:https://www.pythonheidong.com/blog/article/9655/8e14501f734200cd728b/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!