前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【SQL Server】系统学习之一:表表达式

【SQL Server】系统学习之一:表表达式

作者头像
小端
发布2018-04-11 10:31:13
8200
发布2018-04-11 10:31:13
举报
文章被收录于专栏:java架构师

本节讨论的相关内容包括:视图、派生表、CTE、内联表值函数

场景:如果要查询一组数据(例如聚合数据,也就是几个表聚合在一起的数据),这些数据并未在数据库中以表的形式存在。

1、视图:通常用来分解大型的查询。使查询更容易,无需在临时表中复制或者存储数据。视图存于数据库,适用于所有批处理的数据库对象。不适用于单个T-SQL的批处理。

create view myview 

as

select ......

2、派生表(内联视图) 

select ....

from(select .....) as a

完全虚拟,优化器不会为它生成单独的计划。经过编译,会合并外部查询和内部查询。不会是性能降低或提高。

出现多引用时比较麻烦,需要多次重复定义、多次查询。

不允许使用order by(除非和top一起使用)

派生表不能使相关的(where 外部查询表.a=内部查询表.a)[除了apply]

3、CTE

可定义多个

with c1 as

()

c2 as

()

不可嵌套,但为了实现和嵌套派生表相同的效果,可以在c2中使用c1

多引用优势,在接下来的查询中,多次引用cte,替代派生表的重复定义,多次查询方案。 好处是写法简单,但是实质,仍然是重新组织查询,直接访问底层的对象。所以如果数据表中包含大量的行,此时应该考虑使用临时表或表变量,减少访问基础表的次数为一次。

很重要的一个用处:递归

with emp as

(

select empid,empname ,mgrid from employees where empid=5

union all

select empid,empname ,mgrid from employees as em

join emp on emp.mgrid=em.empid

)

select * from emp

option (maxrecursion 2) 最大递归次数

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2014-08-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档