SqlServer视图查询效率测试

一.  测试背景
开发一个项目,数据库用的是sqlserver。账号表数据有一两百万,不算大,也不算小。在考虑是否要使用视图,担忧效率,百度了下资料,众说纷纭,好吧,实践是最好的证实,那么咱们就来测试吧。

二.  测试环境
WIN8系统,内存8G,普通磁盘,sqlserver2012 。

三.  表和视图结构(因为用的是公司的表,因此避免纠纷我把字段给涂掉了)
 
 
 
 

四. 数据量大小html

AccountsData表和AccountsInfo各有400万数据,那么视图VAccounts毫无疑问也是400万条数据。

五. 开始测试
1. 咱们查询视图的时候会利用到基础表的索引吗?这里我利用UserID来作WHERE查询1000条数据。下面两个截图分表是查询的结果,咱们能够清楚到看到查基础表AccountsInfo与查视图VAccounts的效率是没有差异的,因此咱们能够肯定查视图一样会利用到基础表的索引。
 
 
2. 从上面的测试咱们能够看到,利用索引查基础表和视图几乎没有什么区别,那么若是咱们不利用索引字段来查询呢?好比Like。下面是我查字段Nickname带有“南方1999”字符的数据记录,从两次结果咱们能够清楚的看到两次查询几乎没有任何区别。
 
 

. 测试结果sql

能够看到在sqlserver2012中视图不会影响查询效率,因此咱们能够放心的使用。
相关文章
相关标签/搜索