您的位置:首页 > 数据库

数据库SQL Server2012笔记(四)——多表查询、子查询、分页查询、用查询结果创建新表和外连接

2017-06-16 09:34 429 查看
1、多表查询
1)笛卡尔集:

select * from 表名1,表名2
select * from 表名1。表名2 where 表名1.字段名=表名2.字段名

注:

若有两张表有同样名字的字段,则使用时需带表名(别名)。
order by 置于where 条件之后。

2)自连接:同一张表的连接查询。将一张表视为两张表或多张表。

eg:显示公司每一个员工名字和他的上级的名字。将emp表看做两张表worker和boss

select worker.ename 雇员,boss.ename 老板 from emp worker,emp boss where worker.mgr=boss.empno

2、子查询(嵌套查询):嵌入在其他sql语句中的select语句。

1)单行子查询:仅仅返回一行数据的子查询语句。
2)多行子查询:返回多行数据的子查询。
3)在from子句中使用子查询。
说明:
当在from子句中使用子查询时,该子查询会被作为一个视图(暂时表)来对待,因此也叫做内嵌视图。

当在from子句中使用查询时。必须给子查询指定别名。

3、分页查询
1)top n:前n条记录。

select top 5 * from emp order by hiredate
显示第5个到第9个人的信息(按sal高低)

select top 5 from emp where empno not in (select top 4 empno from emp order by sal desc) order by sal desc

identity(1,1):表示字段自增长,从“1”開始增长。每次加“1”。

create table test (testId int primary key identity(1,1))

4、用查询结果创建新表

select * into 还有一个表名 from 表名
删除表中的反复记录

select distinct * into #temo(新表) from 表名1
delete from 表名1
insert into 表名1 select * from #temp
drop table #temp

5、外连接:

左外连接:左边的表的记录所有显示,假设没有匹配的记录,用Null填补。
右外连接:右边的表的记录所有显示。假设没有匹配的记录,用Null填补。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐