数据库之表查询,单表、多表,子查询

基本查询语句及方法
from
where
group by
having
distinct
order by
limit
....

连表
inner join
left join
right join
union

子查询

书写顺序
select id,name from emp where id > 3 and id < 6;
执行顺序
from # 确定到底是哪站表
where # 根据过来条件 筛选数据
select # 拿出筛选出来的数据中的某些字段

select * from emp\G; 当表字段特别多的时候 结果的排版可能会出现混乱的现象 你可以在查询语句加\G来规范查询结果

# 1.查询id大于等于3小于等于6的数据
select * from emp where id >= 3 and id <= 6;
select * from emp where id between 3 and 6;
上述语句完全等价
# 2.查询薪资是20000或者18000或者17000的数据
select id,name from emp where salary = 20000 or salary = 18000 or salary = 17000;
select id,name from emp where salary in (20000,18000,17000);
# 3.查询员工姓名中包含o字母的员工姓名和薪资
模糊匹配 like
%:匹配多个任意字符
_:匹配一个任意字符
select name,salary from emp where name like ‘%o%‘;
# 4.查询员工姓名是由四个字符组成的员工姓名与其薪资
select name,salary from emp where name like ‘____‘;
# 5.查询id小于3或者大于6的数据
select * from emp where id < 3 or id > 6;
select * from emp where id not between 3 and 6;
# 6.查询薪资不在20000,18000,17000范围的数据
select id,name from emp where salary not in (20000,18000,17000);
# 7.查询岗位描述为空的员工名与岗位名 针对null判断的时候只能用is 不能用=
select name,post from emp where post_comment = Null;
select name,post from emp where post_comment is Null;

MySQL对大小写不敏感

group by 分组

# 1.按部门分组
select * from emp group by post;
分组之后应该做到最小单位是组,而不应该再展示组内的单个数据信息

MySQL中分组之后 只能拿到分组的字段信息 无法直接获取其他字段信息
但是你可以通过其他方法(聚合函数)简介的获取

如果你的MySQL不报错 说明严格模式没有设置
show variables like ‘%mode%‘;
set session 当前窗口有效
set global 全局有效
set global sql_mode="strict_trans_tables,only_full_group_by";
select * from emp group by post;
select id,name from emp group by post;
select name from emp group by post;
# 2.获取每个部门的最高工资 聚合函数 max min avg sum count
select post,max(salary) from emp group by post;
给字段取别名
select post as ‘部门‘,max(salary) as ‘最高工资‘ from emp group by post;
select post ‘部门‘,max(salary) ‘最高工资‘ from emp group by post;
# 每个部门的最低工资
select post,min(salary) from emp group by post;
# 每个部门的平均工资
select post,avg(salary) from emp group by post;
# 每个部门的工资总和
select post,sum(salary) from emp group by post;
# 每个部门的人数
select post,count(age) from emp group by post;
select post,count(salary) from emp group by post;
select post,count(id) from emp group by post;
select post,count(post_comment) from emp group by post;
在统计分组内个数的时候 填写任意非空字段都可以完成计数,推荐使用能够唯一标识数据的字段
比如id字段
"""
聚合函数会自动将每一个分组内的单个数据做想要的计算,无需你考虑

"""

# 3.查询分组之后的部门名称和每个部门下所有的学生姓名
select post,group_concat(name) from emp group by post;
select post,group_concat(‘DSB‘,name) from emp group by post;
group_concat()能够拿到分组后每一个数据指定字段(可以是多个)对应的值

select post,group_concat(name,": ",salary) from emp group by post;

concat
select concat("NAME: ",name),concat("SAL: ",salary ) from emp;

小技巧:
concat就是用来帮你拼接数据
concat 不分组情况下使用
group_concat 分组之后使用

# 查询每个员工的年薪
select name,salary*12 from emp;

# 刚开始查询表,一定要按照最基本的步骤,先确定是哪张表,再确定查这张表也没有限制条件,再确定是否需要分类,最后再确定需要什么字段对应的信息
""" +

你应该将每一步操作产生的结果都当成是一张新的表
然后基于该表再进行其他的操作
"""
1. 查询岗位名以及岗位包含的所有员工名字group_concat
2. 查询岗位名以及各岗位内包含的员工个数count
3. 查询公司内男员工和女员工的个数count
4. 查询岗位名以及各岗位的平均薪资avg
5. 查询岗位名以及各岗位的最高薪资max
6. 查询岗位名以及各岗位的最低薪资min
7. 查询男员工与男员工的平均薪资,女员工与女员工的平均薪资avg

"""
聚合函数 max min sum count avg只能在分组之后使用
如果一张表没有写group by默认所有的数据就是一组
"""
书写顺序
select
from
where
group by

执行顺序
from
where
group by
select

8、统计各部门年龄在30岁以上的员工平均工资

# 先获取年轻在30岁以上的员工
select post,avg(salary) from emp where age > 30 group by post;
"""
写sql语句的时候 一定不要一口气写完
前期先按照步骤一步步写
写一步查询看一下结果然后基于当前结果再往后写
"""

having
跟where是一模一样的 也是用来筛选数据
但是having是跟在group by之后的
where是对整体数据做一个初步的筛选
而having是对分组之后的数据再进行一次针对性的筛选
1、统计各部门年龄在30岁以上的员工平均工资,
并且保留平均工资大于10000的部门
select post,avg(salary) from emp where age > 30 group by post having avg(salary) > 10000;
select post,avg(salary) from emp where age > 30 group by post where avg(salary) > 10000; # 报错

# 强调:having必须在group by后面使用
select * from emp having avg(salary) > 10000; # 报错

执行顺序
from
where
group by
having
select

distinct去重
多重复的数据进行一个去重
"""
去重必须数据是一模一样的才能去重
只要有一个不一样 都不能算是的重复的数据
"""
select distinct id,age from emp;

执行顺序
from
where
group by
having
select
distinct

order by 排序
默认是升序 asc
也可以变成降序 desc

select * from emp order by salary;
select * from emp order by salary asc;
select * from emp order by salary desc;
select * from emp order by age,salary; # 先按照age做升序 age相同的情况下再按照salary做升序
select * from emp order by age asc,salary desc; # 先按照age做升序 age相同的情况下再按照salary做升序

# 统计各部门年龄在10岁以上的员工平均工资,
# 并且保留平均工资大于1000的部门,然后对平均工资进行排序
select post,avg(salary) from emp where age > 10 group by post having avg(salary) > 1000 order by avg(salary);

limit 限制展示数据的条数
select * from emp limit 5; # 只展示数据的五条
select * from emp limit 5,5;

"""
当limit只有一个参数的时候 表示的是只展示几条
当limit有两个参数的时候 第一个参数表示的起始位置 第二个参数表示从起始位置开始往后展示的条数

"""
# 查询工资最高的人的详细信息
# 先按照薪资排序
# 再用limit限制 只取一条

select * from emp order by salary desc limit 1;

# 在编程中 只要看到reg开头的 基本上都是跟正则相关

正则
select * from emp where name regexp ‘^j.*(n|y)$‘;

jason
jssdsdsay
jy
jnn

多表查询

"""
表查询分为两大类
1.联表查询
2.子查询
"""
select * from emp,dep; 产生的结果是一个笛卡尔积

# 查询部门为技术部的员工及部门信息

有专门帮你做连表的方法
内连接(inner join)

左连接(left join)

右连接(right join)

全连接(union) # 只要将左连接和右连接的sql语句 加一个union就变成全连接

select * from emp left join dep on emp.dep_id = dep.id
union
select * from emp right join dep on emp.dep_id = dep.id;

子查询
将一张表的查询结果作为另外一个sql语句的查询条件

select name from dep where id = (select dep_id from emp where name = ‘jason‘);

# 2.每个部门最新入职的员工
# 思路:先查每个部门最新入职的员工,再按部门对应上联表查询

select t1.id,t1.name,t1.hire_date,t1.post,t2.* from emp as t1
inner join
(select post,max(hire_date) as max_date from emp group by post) as t2
on t1.post = t2.post
where t1.hire_date = t2.max_date
;

# 可以给表起别名
# 可以给查询出来的虚拟表起别名
# 可以给字段起别名

原文地址:https://www.cnblogs.com/zhangchaocoming/p/11391987.html

时间: 2024-11-09 04:42:08

数据库之表查询,单表、多表,子查询的相关文章

表连接查询与where后使用子查询的性能分析。

子查询就是在一条查询语句中还有其它的查询语句,主查询得到的结果依赖于子查询的结果. 子查询的子语句可以在一条sql语句的FROM,JOIN,和WHERE后面,本文主要针对在WHERE后面使用子查询与表连接查询的性能做出一点分析. 对于表连接查询和子查询性能的讨论众说纷纭,普遍认为的是表连接查询的性能要高于子查询.本文将从实验的角度,对这两种查询的性能做出验证,并就实验结果分析两种查询手段的执行流程对性能的影响. 首先准备两张表 1,访问日志表mm_log有150829条记录(相关sql文件已放在

mysql表数据增删改查、子查询

//操作数据表中的记录 create table user2( id smallint unsigned primary key AUTO_INCREMENT, username varchar(20) not null, password varchar(20) not null, age tinyint not null default 10, sex boolean ) --insert-- insert user2 values(null,'孙千','123',25,1);//自增序列可

Hibernate 笔记 HQL查询 条件查询,聚集函数,子查询,导航查询

本笔记继续使用dept部门表,emp员工表,一对多多对一双向映射. 1 条件查询 1.1    查询 员工表emp中 年龄eage小于30,月薪esal大于20000的员工姓名ename sql:select ename from emp where eage<? and esal >?; hql: select ename from Emp where eage<? and esal >? 1.2 问号的设置与别名 问号(?)的设置使用.setParameter(位置, 属性值)

1.子查询知识体系,单行子查询,多行子查询

 1查询工资比scott高的员工信息 A 第一步:查询出scott这个员工的工资 select sal from emp where ename = 'SCOTT'; B 第二步:查询出工资比scott高的员工信息 select * fromemp where sal >3000; 总结: 子查询的本质:多个select语句的嵌套 2:子查询的知识体系搭建 A 合理的书写风格 B 子查询外面()不要忘记 C 子查询和主查询可以查询的是同一张表,也可以不是同一张表 只要子查询返回的结果,主查询

子查询一(WHERE中的子查询)

子查询 子查询就是指的在一个完整的查询语句之中,嵌套若干个不同功能的小查询,从而一起完成复杂查询的一种编写形式,为了让读者更加清楚子查询的概念. 子查询返回结果子查询可以返回的数据类型一共分为四种: 单行单列:返回的是一个具体列的内容,可以理解为一个单值数据: 单行多列:返回一行数据中多个列的内容: 多行单列:返回多行记录之中同一列的内容,相当于给出了一个操作范围: 多行多列:查询返回的结果是一张临时表: 在WHERE子句中使用子查询 在WHERE子句之中处理单行单列子查询.多行单列子查询.单行

mysql 数据操作 子查询 带比较运算符的子查询

带比较运算符的子查询 #比较运算符:=.!=.>.>=.<.<=.<> #查询大于所有人平均年龄的员工名与年龄 思路 先拿到所有人的平均年龄然后 再用另外一条sql语句 进行比较 拿所有员工的年龄 > 所有人的平均年龄 做比较 mysql> select name,age from employee where age >(select avg(age) from employee) ; +------+------+ | name | age | +

Mysql数据库理论基础之五--SELECT单多表查询、子查询、别名

一.简介 由MySQL AB公司开发,是最流行的开放源码SQL数据库管理系统,主要特点: 1.是一种数据库管理系统 2.是一种关联数据库管理系统 3.是一种开放源码软件,且有大量可用的共享MySQL软件 4.MySQL数据库服务器具有快速.可靠和易于使用的特点 5.MySQL服务器工作在客户端/服务器模式下,或嵌入式系统中 InnoDB存储引擎将InnoDB表保存在一个表空间内,该表空间可由数个文件创建.这样,表的大小就能超过单独文件的最大容量.表空间可包括原始磁盘分区,从而使得很大的表成为可能

MySQL单表的CRUD及多表查询

数据库表的增删改查操作: 增.删.改 查: 单表查询 简单查询.where约束.group by分组.聚合查询.having过滤.order by排序.limit限制.正则匹配 多表查询 连表查询:交叉查询.>內连查询.左外连接查询.右外连接查询.全外链接查询.连接结果筛选查询 子查询 :带关键字in的子查询.带比较运算符的子查询.带关键字exists的布尔判断结果查询 表记录增删改总结: MySQL数据操作: DML 在MySQL管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包

python 之 Django框架(orm单表查询、orm多表查询、聚合查询、分组查询、F查询、 Q查询、事务、Django ORM执行原生SQL)

12.329 orm单表查询 import os if __name__ == '__main__': # 指定当前py脚本需要加载的Django项目配置信息 os.environ.setdefault("DJANGO_SETTINGS_MODULE", "orm_demo.settings") import django django.setup() # 启动Django项目 from app01 import models #返回QuerySet对象的方法: r

MySQL数据库学习笔记(六)----MySQL多表查询之外键、表连接、子查询、索引

注:本文转自:http://www.cnblogs.com/smyhvae/p/4042303.html 本章主要内容: 一.外键 二.表连接 三.子查询 四.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复的,不允许为空,用来保证数据完整性 外键:是另一表的主键, 外键可以有重复的, 可以是空值,用来和其他表建立联系用的.所以说,如果谈到了外键,一定是至少涉及到两张表.例如下面这两张表: 上面有两