是一个
select * from myView
比查询本身更快地创建视图(为了拥有相同的resultSet):
select * from ([query to create same resultSet as myView])
?
我不完全清楚视图是否使用了某种缓存,使其比简单查询更快。
是一个
select * from myView
比查询本身更快地创建视图(为了拥有相同的resultSet):
select * from ([query to create same resultSet as myView])
?
我不完全清楚视图是否使用了某种缓存,使其比简单查询更快。
当前回答
如果创建物化视图(带有模式绑定),可能会更快。非物化视图的执行就像常规查询一样。
其他回答
不。View只是实际的长SQL查询的一种简短形式。但是,你可以说实际查询比视图命令/查询更快。
首先视图查询将转换为简单查询,然后执行,因此视图查询将比简单查询执行更多的时间。
当您使用连接b/w多个表时,可以使用sql视图,以简单的方式一次又一次地重用复杂的查询。
我无意中看到了这个帖子,只是想分享Brent Ozar的这篇文章,作为使用可用性组时的考虑。
布伦特·欧扎尔报道
我希望这两个查询的执行是相同的。视图只不过是一个存储的查询定义,视图没有缓存或存储数据。当您运行第一个查询时,优化器将有效地将其转换为第二个查询。
如果创建物化视图(带有模式绑定),可能会更快。非物化视图的执行就像常规查询一样。
视图的目的是一遍又一遍地使用查询。为此,SQL Server、Oracle等通常会提供视图的“缓存”或“编译”版本,从而提高其性能。一般来说,这应该比“简单”查询执行得更好,但如果查询确实非常简单,好处可能可以忽略不计。
现在,如果您正在执行一个复杂的查询,请创建视图。