SQL 数据库 子查询及示例
子查询,又叫做嵌套查询。
将一个查询语句做为一个结果集供其他SQL语句使用,就像使用普通的表一样,被当作结果集的查询语句被称为子查询。
子查询有两种类型:
一种是只返回一个单值的子查询,这时它可以用在一个单值可以使用的地方,这时子查询可以看作是一个拥有返回值的函数;
另外一种是返回一列值的子查询,这时子查询可以看作是一个在内存中临时存在的数据表。
示例:
--创建一个数据库,建立一个部门表格和部门人员表格
Create database gongs --创建一个gongs的数据库
go
use gongs --使用这个数据库
go
create table bm --添加一个bm的表格
(
bbian int primary key not null, --添加部门编号bbian 整数类型,用primary key约束来创建bbian为主键 具有唯一性,not null具有非空性
bname varchar(20),--添加部门名字
bceo varchar(20),--添加部门领导名字
bdh varchar(20),--添加部门电话
)
go
create table ry --添加一个部门人员ry的表格
(
bian int primary key identity(1001,1) not null,--添加人员编号,primary key identity(1001,1)从1开始,每次增长1,添加values时不用添加此列
name varchar(20),--添加部门人员名字
xingbie char(10),--添加xingbie
age int,--添加年龄
sfz varchar(20),--添加身份证号
dh varchar(20),--添加电话号码
bcode int,--部门编号
)
go --向部门表bm中插入数据
insert into bm values(101,'人事部','袁天罡','')
insert into bm values(102,'业务部','李元吉','')
insert into bm values(103,'企划部','公孙胜','')
insert into bm values(104,'客服部','冯程程','') --插入人员列表信息
insert into ry values('袁天罡','男',28,'','',101)
insert into ry values('袁大','男',25,'','',101)
insert into ry values('袁二','女',27,'','',101) insert into ry values('李元吉','男',25,'','',102)
insert into ry values('李元a','女',23,'','',102)
insert into ry values('李元b','女',24,'','',102) insert into ry values('公孙胜','男',28,'','',103)
insert into ry values('公孙a','女',23,'','',103)
insert into ry values('公孙b','女',24,'','',103)
insert into ry values('公孙吉','男',25,'','',103)
insert into ry values('公孙c','男',23,'','',103) insert into ry values('冯程程','女',25,'','',104)
insert into ry values('冯锡范','男',32,'','',104)
insert into ry values('冯斯托洛夫斯基','男',20,'','',104)
go select * from bm
select * from ry --插入一条错误数据 显示一下外键是什么作用
insert into ry values('甲鱼','女',26,'','',108) --显示一下主键的作用
insert into bm values(101,'人事部','钱八','') ---查询人数最多的部门里年龄最大的人的信息
select bcode from ry group by bcode having COUNT(*)>4--查找人数最多的部门
select MAX(age) from ry where bcode=103--查找里面最大年龄
select bian from ry where bcode=103 and age =28--查找这个人的编号
--子查询的方法:
select * from ry where bian=
(select bian from ry where bcode=103 and age =28) --按照年龄从小到大排序,取789号人员的所有信息
select top 3 * from ry where bian not in
(select top 6 bian from ry order by age) order by age --查找所有男同志里面年龄最大的人的信息
select*from ry where bian=
(select top 1 bian from ry where age=
(select MAX(age) from ry where xingbie='男')) --分页查询
select top 5 * from ry
--6~10
select top 5 * from ry where bian not in
(select top 5 bian from ry)
--11-14
select top 5 * from ry where bian not in
(select top 10 bian from ry) --能分多少页
select ceiling(( select COUNT(*)from ry)/5.0) --将人员表显示出来 并且将部门编号变为部门名称显示
select name , xingbie ,(select bname from bm where bm.bbian = ry.bcode) from ry
SQL 数据库 子查询及示例的更多相关文章
- SQL 数据库 子查询、主外键
子查询,又叫做嵌套查询. 将一个查询语句做为一个结果集供其他SQL语句使用,就像使用普通的表一样,被当作结果集的查询语句被称为子查询. 子查询有两种类型: 一种是只返回一个单值的子查询,这时它可以用在 ...
- SQL Fundamentals: 子查询 || 行列转换(PIVOT,UNPIVOT,DECODE),设置数据层次(LEVEL...CONNECT BY)
SQL Fundamentals || Oracle SQL语言 子查询(基础) 1.认识子查询 2.WHERE子句中使用子查询 3.在HAVING子句中使用子查询 4.在FROM子句中使用子查询 5 ...
- C#构造方法(函数) C#方法重载 C#字段和属性 MUI实现上拉加载和下拉刷新 SVN常用功能介绍(二) SVN常用功能介绍(一) ASP.NET常用内置对象之——Server sql server——子查询 C#接口 字符串的本质 AJAX原生JavaScript写法
C#构造方法(函数) 一.概括 1.通常创建一个对象的方法如图: 通过 Student tom = new Student(); 创建tom对象,这种创建实例的形式被称为构造方法. 简述:用来初 ...
- 一文让你彻底理解SQL关联子查询
员工表的主要信息: 需求:检索工资大于同职位的平均工资的员工信息. 直觉的做法 员工多,而相应的职位(如销售员.经理.部门经理等)少,因此首先想到的思路是对职位分组,这样就能分别得到各个职位的平均工资 ...
- SQL Fundamentals: 子查询 || 分析函数(PARTITION BY,ORDER BY, WINDOWING)
SQL Fundamentals || Oracle SQL语言 子查询(基础) 1.认识子查询 2.WHERE子句中使用子查询 3.在HAVING子句中使用子查询 4.在FROM子句中使用子查询 5 ...
- SQL Fundamentals: 子查询 || WHERE,HAVING,FROM,SELECT子句中使用子查询,WITH子句
SQL Fundamentals || Oracle SQL语言 子查询(基础) 1.认识子查询 2.WHERE子句中使用子查询 3.在HAVING子句中使用子查询 4.在FROM子句中使用子查询 5 ...
- SQL的子查询操作
对于表中的每一个记录,我们有时候需要提取特殊的或者你需要的记录,要提前做一个表的筛选,之后再对你选出的记录做一个修改,此时你必须使用SQL的子查询操作.如:修改id=5的记录的strContent字段 ...
- SQL关联子查询
SQL关联子查询执行顺序: 1.先取到主查询中的相关数据,一次取一行主查询的数据 2.然后传入子查询,进行子查询 3.最后做主查询where筛选,注意子查询的where条件同样需要加在主查询后 参考: ...
- SQL Server 数据库子查询基本语法
一.SQL子查询语句 1.单行子查询 select ename,deptno,sal from emp where deptno=(select deptno ...
随机推荐
- IplImage的数据结构以及遍历方法
一般我们需要对图像直接进行操作的时候,需要知道图像存储的数据结构,这要也就知道了它的遍历方式 在opencv2.4.4版本下,IplImage的数据结构如下(貌似在别的版本下差别也不会太大) 其中比较 ...
- elastic-job 分布式定时任务框架 在 SpringBoot 中如何使用(一)初始化任务并定时执行
第一篇需要实现一个最简单的需求:某个任务定时执行,多台机子只让其中一台机子执行任务 一.安装 分布式应用程序协调服务 zookeeper,安装步骤在链接里面 Linux(Centos7)下安装 zoo ...
- golang显示本机IP代码
package main import ( "fmt" "net" ) func main() { addrs, err := net.InterfaceAdd ...
- 《java笔记》
1.判断是否是整数,包含正数和负数 /** * 判断是否是整数包含正负 */ public static boolean isInteger(String str){ Pattern pattern ...
- [转] AForge.NET 图像处理类
https://www.nuget.org/packages?q=AForge.NET https://baike.baidu.com/item/AForge.NET/114415?fr=aladdi ...
- 部署mariadb高可用
上传文件到opt目录下 Galera能够实现MySQL/MariaDB数据库的主主复制和多主复制等模式,这些复制模式都是同步进行的,同步时间非常短. 每一个节点都可以同时写入和读取,当某一节点发生故障 ...
- [UE4]用向量表示方向
向量的概念 一.物理角度的向量 1)向量就是具有大小和长度的量 2)向量就是空间空的箭头 3)向量可以随意平移 举例:力,force:速度,velcity.这些都是具有大小和方向的量,都可以看成是向量 ...
- 使用HTML5里页面可见性接口判断用户是否正在观看你的页面
转自:http://www.webhek.com/page-visibility 长期以来我们一直缺少一个判断用户是否正在浏览某个指定标签页的方法.用户是否去看别的网站了?他们切换回来了么?现在,HT ...
- more 可翻页查看(一页一页翻动)
命令解释 我们查看数据的时候,使用前面提到的nl与cat.tac等等,都是将文件内容一次性输出到屏幕上,看起来不是很方便,那我们就可以使用这个命令,一页一页查看,前面的数据不至于看不到. 命令说明 [ ...
- 【Unix网络编程】chapter2传输层:TCP,UDP和SCTP
2.1 概述 TCP:复杂,可靠的字节流协议 UDP:简单的,不可靠的数据包协议 SCTP:流控制传输协议 2.2 总图 2.3 用户数据报协议2.4 传输控制协议2.5 流控制传输协议(SCTP)2 ...