day04 查找关键字
day04 查找关键字
昨日内容回顾
基本数据类型之日期相关类型
date :年月日
time :时分秒
datetime:年月日时分秒
year :年
基本数据类型之枚举与集合类型
# 枚举
多选一(性别)
enum('male','female')
# 集合
多选多
set('lookbook','football')
约束条件
1、unsigned:无符号
2、zerofill:0填充
3、not null:非空
4、unique :唯一
5、default :默认值
6、primary key :主键
7、auto_increment:自增 # 配置主键一起使用
约束条件之外键
# 外键是用来记录表和表之间的关系
# 表关系判断 换位思考
1.多对一
换位思考之后一边可以一边不可以 则为多对一
外键字段建在"多"的一方
2.多对多
换位思考之后两边都可以 则为多对多
外键字段建在第三张关系表
# SQL
foreign key(本表外键字段) references 另外一张表名(主键字段)
on update cascade
on delete cascade
# 外键约束
1.在创建表的时候先创建被关联表
2.在录入数据的时候也是先录入被关联表
"""
外键虽然可以强行建立表关系 但是会造成表与表之间的强耦合
有时候当表特别多的情况下 可能不会使用外键来维护关系
而是通过代码层面建立逻辑意义上的关系
"""
今日内容概要
1、表关系之一对一
2、修改表的SQL语句补充
3、表查询关键字
# 基本关键字
select
from
where
group by
having
distinct
order by
limit
regexp
# 多表查询关键字
inner join
left join
right join
union
表关系之一对一
# 场景
客户表与学生表
QQ用户表
以用户表和用户详情表为例
1、先站在用户表的基础之上
问:一个用户能否对应多个用户详情
答:不可以
2、在站在用户详情表基础之上
问:一个用户详情能否对应对个用户
答:不可以
# 结论:换位思考之后两边都不可以,那么表关系有两种
1、没有关系
2、一对一关系
问题:外键字段建在哪呢?
答:理论上建在热河一方都可以,但是最好建在查询频率较高的表中
案例:
create table user2(
id int primary key auto_increment,
name varchar(32),
detail_id int unique, # 一对一,不能重复
foreign key(detail_id) references user_detail(id)
on update cascade
on delete cascade
);
create table user_detail(
id int primary key auto_increment,
addr varchar(32),
phone bigint
);
操作表的SQL语句补充
1、修改表名称
alter table m1 rename m2;
rename table m1 to m2; # 关键字修改,rename ... to
rename table m1 to m2, m3 to m4; # 可以多个修改
2、添加表字段
alter table m1 add pwd int; # 关键字:add
alter table m1 add hobby varchar(32) after name; # 在name字段后面添加hobby字段
alter table m1 add age int first; # 在最上面添加字段
3、删除表字段
alter table m1 drop age;
4、修改字段名和字段类型
# modify:修改字段类型
# change: 同时修改字段类型和字段名称
alter table m1 modify age tinyint; # modify:修改字段类型
alter table m1 change age gender int; # 把age改成gender,并修改字段类型
复制表(了解)
# 查询语句执行的结果也是一张表,可以看成虚拟表
1、复制表结构+记录(key不会复制:主键、外键和索引)
create table mmm select * from m7; # 数据都会复制,但是键不会复制
2、只拷贝表结构(不包含键)
create table mqq select * from m7 where 1=2;
3、拷贝结构包含各种key
create table mqq like m7;
单表查询准备
create table emp(
id int primary key auto_increment,
name varchar(20) not null,
sex enum('male','female') not null default 'male', #大部分是男的
age int(3) unsigned not null default 28,
hire_date date not null,
post varchar(50),
post_comment varchar(100),
salary double(15,2),
office int, #一个部门一个屋子
depart_id int
);
#插入记录
#三个部门:教学,销售,运营
insert into emp(name,sex,age,hire_date,post,salary,office,depart_id) values
('jason','male',18,'20170301','张江第一帅形象代言',7300.33,401,1), #以下是教学部
('tom','male',78,'20150302','teacher',1000000.31,401,1),
('kevin','male',81,'20130305','teacher',8300,401,1),
('tony','male',73,'20140701','teacher',3500,401,1),
('owen','male',28,'20121101','teacher',2100,401,1),
('jack','female',18,'20110211','teacher',9000,401,1),
('jenny','male',18,'19000301','teacher',30000,401,1),
('sank','male',48,'20101111','teacher',10000,401,1),
('哈哈','female',48,'20150311','sale',3000.13,402,2),#以下是销售部门
('呵呵','female',38,'20101101','sale',2000.35,402,2),
('西西','female',18,'20110312','sale',1000.37,402,2),
('乐乐','female',18,'20160513','sale',3000.29,402,2),
('拉拉','female',28,'20170127','sale',4000.33,402,2),
('僧龙','male',28,'20160311','operation',10000.13,403,3), #以下是运营部门
('程咬金','male',18,'19970312','operation',20000,403,3),
('程咬银','female',18,'20130311','operation',19000,403,3),
('程咬铜','male',18,'20150411','operation',18000,403,3),
('程咬铁','female',18,'20140512','operation',17000,403,3);
查找关键字
select:控制查询表中的哪些字段对应的数据
from:控制查询的表
where:筛选
查找关键字之where
# where其实就是对数据进行筛选
# 模糊查询:
关键字:like
关键符号:
%:匹配任意个数的任意字符
_:匹配单个个数的任意字符
1、查询id大于等于3小于等于6的数据
select * from emp where id<=3 and id<=6;
select * from emp where id between 3 and 6; # between:在两者之间
2、查询薪资是20000或者18000或者17000的数据
select * from emp where salary=20000 or salary=18000 or salary=17000; # 比较繁琐
select * from emp where salary in (20000,18000,17000) # 简写之后
3、查询员工姓名中包含o字符的员工姓名和薪资
select name,salary from emp where name like '%o%';
4、查询员工姓名为四个字符组成的员工姓名和薪资
select name,salary from emp where naem like '____';
select name,salary from emp where char_length(name)=4; # 查询名字是4个字符
5、查询id小于3或者大于6的数据
select * from emp where id not between 3 and 6;
6、查询薪资不在20000,18000,17000范围的数据
select * from emp where salary not in (20000,18000,17000);
7、查询岗位描述为空的员工名与岗位名 # 针对null不能用等号,只能用is
select * from emp where post_comment is NULL;
查询关键字之group by分组
分组:按照某个指定的条件将单个的数据分为一个个整体
比如:
按照年龄分组
按照省份分组
按照性别分组
# 格式:
关键字 group by 条件
# as:起别名
# group_concat:用于分组之后获取分组以外的字段数据并支持拼接
# concat:用于分组之前的拼接操作
# concat_ws:当多个字段连接符相同的情况下推荐使用
"""
分组之后不再以单个个体为研究对象 也无法直接再获取单个个体的数据
研究对象应该是分组的整体
分组之后默认只能直接获取到分组的依据 其他字段数据无法直接获取
如果需要实现上述要求 还是修改sql_mode
set global sql_mode='only_full_group_by';
"""
1、获取每个部分的最大薪资
select post,max(salary) from emp group by post;
select post as '部门',max(salary) as '最高薪资' from emp group by post; # as:起别名
2、每个部门的最小薪资
select post as '部门',min(salary) as '最高薪资' from emp group by post;
3、统计每个部门到的人数
select post as '部门',count(id) as '部门人数' from emp group by post;
4、获取每个部门的员工姓名
# group_concat:用于分组之后获取分组以外的字段数据并支持拼接
select post,group_concat(name,':',salary) from emp group by post;
# concat:用于分组之前的拼接操作
select id,concat(name,':',salary) as '呵呵' from emp;
# concat_ws:当多个字段连接符相同的情况下推荐使用
select id,concat_ws('|',name,post,sex,office) from emp;
'''as可以省略但是为了语义更加明确建议不要省略'''
聚合函数:只能配合group by使用
max() :最大值
min() :最小值
sun() :求和
count() :计数
avg() :求平均数
# 上述聚合函数都是在分组之后使用 用于操作整体数据
练习题
1. 查询岗位名以及岗位包含的所有员工名字
select post as '岗位',group_concat(name) as '人员' from emp group by post;
2. 查询岗位名以及各岗位内包含的员工个数
select post,count(id) from emp group by post;
3. 查询公司内男员工和女员工的个数
select sex,count(id) from emp group by sex;
4. 查询岗位名以及各岗位的平均薪资
select post,avg(salary) from emp group by post;
5. 查询岗位名以及各岗位的最高薪资
select post,max(salary) from emp group by post;
6. 查询岗位名以及各岗位的最低薪资
select post,min(salary) from emp group by post;
7. 查询男员工与男员工的平均薪资,女员工与女员工的平均薪资
select sex,avg(salary) from emp group by sex;
查询关键字之having过滤
where与having都是用来筛选数据的
where和having的区别:
where:用于分组之前额筛选
having:用于分组之后的过滤
1、统计各部门年龄在30岁以上的员工平均工资,并且保留平均工资大于10000的部门
select post,avg(salary) from emp where age > 30 group by post having avg(salary)>10000;
# 解题思路:大象放冰箱
1、统计各部门的员工平均工资
select post,avg(salary) from emp group by post;
2、统计30岁以上的员工平均薪资
select post,avg(salary) from emp where age > 30 group by post;
3、统计各部门年龄在30岁以上的员工平均工资,并且保留平均工资大于10000的部门
select post,avg(salary) from emp where age > 30 group by post having avg(salary) > 10000;
查询关键字之distinct去重
# 去重的前提是存在一模一样的数据,如果存在主键肯定无法去重
select distinct id,age from emp; # 有id一定去重不了,因为存有主键
select distinct age from emp; # 可以去重
查询关键字之order by排序
order by 默认是升序
默认关键字:
asc :升序
desc:降序
select * from emp order by salary asc; # 工资按升序排列
select * from emp order by salary desc; # 工资按降序排列
# order by支持多个字段数排序(第一个不行,接着往后排)
select * from emp order by age,salary asc;
select * from emp order by age asc,salary desc;
day04 查找关键字的更多相关文章
- 【SQL语句】 - 在所有存储过程中查找关键字,关键字不区分大小写 [sp_findproc]
USE [EShop]GO/****** Object: StoredProcedure [dbo].[sp_findproc] Script Date: 2015/8/19 11:05:24 *** ...
- linux下vim编辑器查找 关键字
在 linux vim 编辑器 下查找 关键字 方法[一] 1?short_open_tag : 它的意思是vim 打开文件的第一行 ? : 它的意思是反向查找 short_open_tag ...
- .net通过iTextSharp.pdf操作pdf文件实现查找关键字签字盖章
之前这个事情都CA公司去做的,现在给客户做demo,要模拟一下签字盖章了,我们的业务PDF文件是动态生成的所以没法通过坐标定位,只能通过关键字查找定位了. 之前在网上看了许多通多通过查询关键字,然后图 ...
- linux日志中查找关键字、前几行、结尾几行,Linux的find用法示例
linux在日志中查找关键字.前几行.结尾几行,Linux的find用法示例 1.linux在日志中查找关键字.前几行.结尾几行 1.1查看日志 前 n行: 1.2查看日志 尾 n行: 1.3根据 关 ...
- js 查找关键字
查找:4种: 1. 查找固定关键字,仅返回位置,可指定开始位置: var i=str.indexOf("kword"[,starti]); str.lastIndexOf(&quo ...
- linux grep (linux查找关键字在php出现的次数)
http://www.th7.cn/system/lin/201508/127681.shtml 查找CleverCode在当前目录以及子目录,所有的php出现大于0的次数. # find -type ...
- vim查找关键字的好方法
当你用vi打开一个文件后,因为文件太长,如何才能找到你所要查找的关键字呢? 在vi里可没有菜单-〉查找 不过没关系,你在命令模式下敲斜杆( / )这时在状态栏(也就是屏幕左下脚)就出现了 “/” 然 ...
- Linux - Shell - 在多个文件中查找关键字
1. 概述 在多个文件中 查找内容 2. 想干啥 目的 在 多个文件 中, 查找内容 准备 之前在 单个文件里 查找过内容 工具 awk 前提 文件有固定格式 查找时有字段的要求 例子 # print ...
- sublime text多文件夹查找关键字
Ctrl+shift+F 快捷键在文件夹内查找,与普通编辑器不同的地方是sublime允许添加多个文件夹进行查找 转自:http://www.douban.com/note/362268947/
随机推荐
- ASP的调试技术解答
一. 调试 ASP.NET 应用程序时出现"未将项目配置为进行调试"的错误信息 症状 当您在 Visual Studio .NET 中调试 ASP.NET 应用程序时,可能会出现下 ...
- Typora和PicGo-Core搭配使用
作用:快速上传图片并获取图片 URL 链接的工具,图片存放到Gitee仓库中,在博客网站发布时不必担心图片转存失败问题 Gitee 创建一个新仓库 生成一个新令牌 生成后只显示一次,请妥善保管 Pic ...
- Go语言核心36讲(Go语言进阶技术十四)--学习笔记
20 | 错误处理 (下) 在上一篇文章中,我们主要讨论的是从使用者的角度看"怎样处理好错误值".那么,接下来我们需要关注的,就是站在建造者的角度,去关心"怎样才能给予使 ...
- 重装系统——联想window 10
大四了,读了四年大学,唉,混的,啥也不会,工作也找不到,真的不知道这大学四年到底干了什么.专业是计算机方向的,但居然,不敢,也不会装电脑系统,大学四年的文件都是乱放的,更那个的是,有些软件卸载不完全, ...
- Vue的第一课
终于学习到Vue了,美滋滋,给自己点个赞 前后端作用: 1.1vs1(一个Vue对象控制一个) <body> <div id="app"> <p> ...
- 【CVE-2020-1948】Apache Dubbo Provider反序列化漏洞复现
一.实验简介 实验所属系列: 系统安全 实验对象:本科/专科信息安全专业 相关课程及专业: 计算机网络 实验时数(学分):2 学时 实验类别: 实践实验类 二.实验目的 Apache Dubbo是一款 ...
- flask 中的endpoint有什么用?
url到view function之间的一个中间概念,默认是view function的名字,相比于直接使用view function, 使用end point 提供了一个命名空间,可以让不同蓝图的v ...
- django前后端分离403 csrf token missing or incorrect
根据这个链接https://stackoverflow.com/a/26639895 这是一个django的跨域访问问题. django,会对合法的跨域访问做这样的检验,cookies里面存储的'cs ...
- IntelliJ IDEA 的 Bean validation 里有什么用
IntelliJ IDEA 的 Bean validation 是指右侧的框. 平时都是缩起来的,今天心血来潮.研究下这个是干嘛的?怎么用. 三个按钮全按下的话,下面的项目就会有三个菜单可选项. C ...
- 基于Netty实现自定义消息通信协议(协议设计及解析应用实战)
所谓的协议,是由语法.语义.时序这三个要素组成的一种规范,通信双方按照该协议规范来实现网络数据传输,这样通信双方才能实现数据正常通信和解析. 由于不同的中间件在功能方面有一定差异,所以其实应该是没有一 ...