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 查找关键字的更多相关文章

  1. 【SQL语句】 - 在所有存储过程中查找关键字,关键字不区分大小写 [sp_findproc]

    USE [EShop]GO/****** Object: StoredProcedure [dbo].[sp_findproc] Script Date: 2015/8/19 11:05:24 *** ...

  2. linux下vim编辑器查找 关键字

    在  linux  vim 编辑器 下查找   关键字 方法[一] 1?short_open_tag : 它的意思是vim 打开文件的第一行 ? : 它的意思是反向查找 short_open_tag ...

  3. .net通过iTextSharp.pdf操作pdf文件实现查找关键字签字盖章

    之前这个事情都CA公司去做的,现在给客户做demo,要模拟一下签字盖章了,我们的业务PDF文件是动态生成的所以没法通过坐标定位,只能通过关键字查找定位了. 之前在网上看了许多通多通过查询关键字,然后图 ...

  4. linux日志中查找关键字、前几行、结尾几行,Linux的find用法示例

    linux在日志中查找关键字.前几行.结尾几行,Linux的find用法示例 1.linux在日志中查找关键字.前几行.结尾几行 1.1查看日志 前 n行: 1.2查看日志 尾 n行: 1.3根据 关 ...

  5. js 查找关键字

    查找:4种: 1. 查找固定关键字,仅返回位置,可指定开始位置: var i=str.indexOf("kword"[,starti]); str.lastIndexOf(&quo ...

  6. linux grep (linux查找关键字在php出现的次数)

    http://www.th7.cn/system/lin/201508/127681.shtml 查找CleverCode在当前目录以及子目录,所有的php出现大于0的次数. # find -type ...

  7. vim查找关键字的好方法

    当你用vi打开一个文件后,因为文件太长,如何才能找到你所要查找的关键字呢?  在vi里可没有菜单-〉查找 不过没关系,你在命令模式下敲斜杆( / )这时在状态栏(也就是屏幕左下脚)就出现了 “/” 然 ...

  8. Linux - Shell - 在多个文件中查找关键字

    1. 概述 在多个文件中 查找内容 2. 想干啥 目的 在 多个文件 中, 查找内容 准备 之前在 单个文件里 查找过内容 工具 awk 前提 文件有固定格式 查找时有字段的要求 例子 # print ...

  9. sublime text多文件夹查找关键字

    Ctrl+shift+F 快捷键在文件夹内查找,与普通编辑器不同的地方是sublime允许添加多个文件夹进行查找 转自:http://www.douban.com/note/362268947/

随机推荐

  1. 内核驱动编译之Makefile shell pwd路径问题

    一般我们在写Makefile的时候为了获取到当前Makefile所在的文件夹路径,会使用TopDIR ?= $(shell pwd)来定义,后续的文件路径都是基于此TopDIR基础上使用. 今天在移植 ...

  2. 🔥完美解决ESlint+Prettier各项配置冲突的语法报错问题(新手向)

    本文重点: 1.解决修改了Prettier默认配置,项目内格式化无法生效 2.解决Prettier缺少配置,函数名和括号之间,自动添加空格 3.settings.json配置项分享 一个程序员,可能非 ...

  3. linux&c 进程控制 课后习题

    (声明:本篇博客只是博主自己的理解,加以整理,目的是总结刚学过的进程知识,不一定绝对正确,非常愿意听客官您提出宝贵意见.) Q1:进程中的全局数据段(全局变量),局部数据段(局部变量),静态数据段的分 ...

  4. [python]Robotframework+Git+jenkins实现持续集成并生成测试报告发送邮件

    1.环境需求 &robotframework(不写搭建,自行百度) & git(不写安装,自行百度) &jenkins 2.安装jenkins 官网下载最新版本https:// ...

  5. linux磁盘空间查看

    du -h --max-depth=1 du -sh df -h

  6. Android 有意思的脚本(打印温度)

    https://github.com/LineageOS/android_hardware_google_pixel/blob/lineage-18.1/thermal/device.mk #!/sy ...

  7. 大一C语言学习笔记(7)---指针篇--什么是指针?什么是指针变量?取地址符“&”的作用是什么?地址运算符“*”的作用是什么,怎么理解两者?

    "指针是C语言的灵魂"这句话一开始我没怎么明白,现在接触了指针,终于知道为什么这么说了,因为....难,真难:下面说一下我对这句话的见解: C语言拥有着其他语言所没有的特性---直 ...

  8. ipython和pip,模块安装方法

    先下载 pip-.tar.gz 解压文件 cmd进入这个加压后的文件 执行 python setup.py install 然后配置环境变量 把 python 下的 Scripts 文件目录添加到 P ...

  9. 你真的懂Redis的5种基本数据结构吗?

    摘要: 你真的懂Redis的5种基本数据结构吗?这些知识点或许你还需要看看. 本文分享自华为云社区<你真的懂Redis的5种基本数据结构吗?这些知识点或许你还需要看看>,作者:李子捌. 一 ...

  10. 记一次 IIS 站点配置文件备份和还原,物理路径文件批量备份

    前言 上一篇文章实现了数据库的批量备份和还原,当然部署在服务器中的IIS站点备份也是一个十分繁琐的事,三四个数量不多的还好,像有一些服务器用了许久,承载几十个站点甚至更多,一个一个备份,再一个一个还原 ...