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

07.16自我总结

数据库查找方式进阶

一.单表查询

1.查看表单选择段落

1.disinct
  • 所有内容去重:select disinct * from 表名称;
  • 指定字段去重:select disinct 字段 from 表名称;
注意点
  • disinct 必须写在开头
2.查看多个字段内容
  • 查看多个字段内容:select 字段一,字段2 from 表名称;
  • 查看全部以及字段内容:select * 字段1 from 表名称;

注意点

  • 有*和字段的时候,*必须写在字段的前面
3.对于查看段落横坐标进行重命名显示
  • select 字段名称 as 显示字段名称 from 表名称;
  • select 字段名称 显示字段名称 from 表名称
4.选择指定表指定段落

select 指定表.字段 from 表1,表2

5.四则运算

四则运算包括加减乘除

select 字段1 四则运行符号 字段2 from 表名称

6.函数运算

语法:select 函数(字段1) from 表名称

统计函数

  • max:最大值
  • min:最小值
  • avg:平均值
  • sum:求和
  • count:数量

2.where

1.常见的表达式
比较运算符介绍
<,<=,>,>=,=,!=小于,小于等于,大于,大于等于,等于,不等于
in(set)成员运算,看值有没有再列表里面
like模糊查找:%代表零个或多个字符,_代表一个字符
is null判断是否为空
between A and B显示某个区间:A-B 包括A和B
逻辑运算符介绍
and且,多个条件同时满足
or或者,满足多个条件其中一条
not不成立
2.特殊的表达式

binary

区分大小写

语法:select 段落 from 表明 where binary 字段....................................

3.group by/having

分组

语法

select....from 表名

where .......

group by 字段名称 #如果这里有多个字段,A,B,用,连接表示具有相同字段A以及相同字段B进行分组

having 判断内容

注意:

  • having 必须分组后才能使用
  • 分组后只能用having
  • group_concat(字段),可以把由于分组后造成的折叠内的数据全部显示

4.ord by

排序

语法:默认为升序

ord by 字段名称

固定升序或者降序

  • 升序 :ord by 字段名称 asc
  • 降序:ord by 字段名称 desc

多个条件排序主次关系

ord by 主字段,次字段

5.limit

限制显示记录

对于单页表操作

limit start count

  • 其中start可以不填,不填默认从0开始,0是第一天记录
  • start表示起始位置,count 表示记录的数量

对于多页操作

分页原理:先查询总数据条数 设为a
确定每页数量b
总页数为c = a / b 如果除不尽则需要加1 例如 10 / 3 正确页数为4
查询语句的起始位置为s = 当前页数d 减去1 乘以每页数量
即 s = (d - 1) * b

limit s b

6.正则匹配

语法 :where 字段名称 regexp '正则表达式'

注意:正则表达式不包括特殊字符如\w

二.多表查询

1.笛卡尔积查询

语法:select *from 表1,表2

他会把多个表每行与另外个表统统匹配上,其中会有一些脏数据,我们可以用里面值的关系进行连接

2.内连接查询

其本质就是笛卡尔积查询

区别是把,变成 join

且不能用where,要先用on根据里面值的关系拼接好了再用 where

3.左连接查询

左表中记录的无论是否有匹配关系都全部显示,右表中仅显示匹配成功的记录

语法:select *from 表1 left join,表2

4.右连接查询

右表中记录的无论是否有匹配关系都全部显示,左表中仅显示匹配成功的记录

语法:select *from 表1 right join 表2

5.全外连接查询

无论是否匹配成功,两边表中的记录都要全部显示
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;

可以完成全外连接

6.注意

在三表以及三表以上查询的时候,表1 join 表2 join 表三,其意思是表1与表2连接后的表再与表3进行连接

如果三表连接时候没有用join而是用,进行连接表示同时查询3个表

三.子查询

1.查询对象当查找对象

将查找后的内容作为查找的值或者查找的对象,

如果要作为一个表当作查找对象,要对于查找后的表进行重命名语法如下

select .... from (select ....from .......) as 新名字

2.in关键字查询

"查询平均年龄大于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;

3.exists关键字查询

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.cnblogs.com/pythonywy/p/11196859.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2008数据库实验 1.SQL SEVER 2000的系统工具使用交互方式建库、建表 2.T—SQL的简单查询连接查询 3.子查询及组合 4.数据控制、数据导入/导出、数据备份和恢复 实验1 SQL SEVER 2000的系统工具使用交互方式建库、建表实验 实验目的和要求:了解SQL SEVER 2000的功能及组成,熟练掌握利用SQL SEVER 2000企业管理器和查询分析器创建数据库、表、索引和修改表结构及向数据库输入数据、修改数据和删除数据的操作方法和步骤,掌握定义数据约束条件的操作。 实验内容和步骤: (1)熟悉SQL SEVER 2000的界面和操作。 (3)熟悉企业管理器和查询分析器的界面和操作。 (3)创建数据库和查看数据库属性。 (4)创建表、确定表的主码和约束条件。 (5)查看和修改表的结构。 (6)向数据库输入数据,观察违反列级约束时出现的情况。 (7)修改数据。 (8)删除数据,观察违反表级约束时出现的情况。 实验2 T—SQL的简单查询连接查询 实验目的和要求:,了解SQL语句的数据定义与数据更新功能,了解SQL语句的查询功能,掌握SQL的数据定义语句的用法,熟练掌握SQL的插入、修改和删除语句的操作,熟练掌握使用SQL语句进行数据库的简单查询连接查询。 实验内容和步骤: (1)在SQL SEVER 2000的查询分析器里,用SQL语句建库、建表并插入记录。 (2)修改表结构,包括修改属性列的数据类型,增加新的属性列,删除已有的属性列。 (3)使用单个元组和多元组插入。 (4)简单查询操作,包括投影、选择、数据排序、模糊匹配查询等。如果结果不正确,要进行修改,直至正确为止。 (5)连接查询操作,包括等值连接、自然连接、一般连接、自身连接、外连接。 实验3 子查询及组合 实验目的和要求:了解SQL语句的查询功能,理解视图的概念。熟练掌握使用SQL语句进行数据库的嵌套查询及组合查询的操作;掌握视图创建语句和视图的使用方法,加深对视图作用的理解。 实验内容和步骤: (1)在DBMS的交互式环境里,用SQL语句建库、建表并插入记录。 (2)使用In、比较符和Exists操作符进行嵌套查询操作。 (3)分组查询,包括分组条件表达、选择组条件表达的方法。 (4)集合查询。 (5)使用视图创建语句建视图,通过视图查询数据 (6)带子查询的修改和删除 (7)通过视图修改和删除数据 实验4 数据控制、数据的导入/导出、数据库备份和恢复 实验目的和要求:掌握数据控制(安全性)的方法,了解SQL SEVER 2000的数据备份和恢复机制,掌握SQL SEVER 2000数据库备份和恢复的方法。 实验内容和步骤: (1)使用SQL对数据进行安全性控制,包括授权和权利收回。 (2)查看授权和权利收回后的结果 (3)SQL SEVER 2000工具对表的数据导出到其它格式的文件。 (4)将其它格式的文件数据导入到数据库。 (5)使用SQL SEVER 2000工具创建一个数据库的备份(海量备份、增量备份)。 (6)使用SQL SEVER 2000工具及所创建的数据库备份恢复这个数据库
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值