一.  测试背景
开发一个项目,数据库用的是sqlserver。帐号表数据有一两百万,不算大,也不算小。在考虑是否要使用视图,担心效率,百度了下资料,众说纷纭,好吧,实践是最好的证明,那么我们就来测试吧。
二.  测试环境
WIN8系统,内存8G,普通磁盘,sqlserver2012 。
三.  表和视图结构(由于用的是公司的表,所以避免纠纷我把字段给涂掉了)
 
 
 
 

四. 数据量大小

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

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

. 测试结果

可以看到在sqlserver2012中视图不会影响查询效率,所以我们可以放心的使用。

最新文章

  1. UAC在注册表中的对应位置
  2. Eclipse Java class修改后的即时编译
  3. 带有可点击区域的图像映射:HTML <map> 标签
  4. HW5.17
  5. HttpWebRequest提高效率之连接数,代理,自动跳转,gzip请求等设置问题
  6. ACM比赛技巧
  7. ubuntu高版本环境变量问题
  8. Linux 静态库与共享库的使用
  9. .Net3月份开发札记
  10. 笔记:Maven 插件配置 - maven-jar-plugin
  11. Django 个性化管理员站点
  12. 如何将一个二进制的xxx.bin文件轻松转为C语言数组
  13. Google Quic协议
  14. java_25.1字节转为字符OutputStreamWriter
  15. python基础 (迭代器回顾,生成器,推导式)
  16. Java基础学习篇---------多线程
  17. wxpython 窗口排版- proportion/flag/border参数说明
  18. Badboy安装和介绍
  19. Navicat 大小写
  20. PHP变量问题,Bugku变量1

热门文章

  1. CSS-03-组选择器
  2. php--->自己封装的简易版mvc框架
  3. springboot mybatis 多数据源配置支持切换以及一些坑
  4. 按照相应的格式获取系统时间并将其转化为SQL中匹配的(date)时间格式
  5. PAT乙级(Basic Level)真题,福尔摩斯的约会
  6. FFMPEG学习----遍历所支持的解码器
  7. OpenGL学习网址2
  8. 文件传输协议-FTP
  9. Redis5.x五种数据类型常见命令
  10. 11-MyBatis01