相关文章推荐
气宇轩昂的蜡烛  ·  开始在 WSL 上使用 Git | ...·  1 年前    · 
高大的回锅肉  ·  python交流论坛推荐,python技术交 ...·  1 年前    · 
挂过科的烤面包  ·  输出流转输入流_51CTO博客_java输出 ...·  2 年前    · 
豪气的电脑桌  ·  Hikari 数据源参数配置描述 - 简书·  2 年前    · 
不羁的松树  ·  SSIS 目录 - SQL Server ...·  2 年前    · 
Code  ›  SQLServer中使用索引视图(物化视图)开发者社区
索引 sqlserver 数据库视图 物化视图
https://cloud.tencent.com/developer/article/1342577
狂野的火车
2 年前
作者头像
跟着阿笨一起玩NET
0 篇文章

SQLServer中使用索引视图(物化视图)

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > 跟着阿笨一起玩NET > SQLServer中使用索引视图(物化视图)

SQLServer中使用索引视图(物化视图)

作者头像
跟着阿笨一起玩NET
发布 于 2018-09-19 11:16:36
2.3K 0
发布 于 2018-09-19 11:16:36
举报

物化视图:以前用的普通的视图,普通视图就是一段逻辑语句,对性能没有任何的提升,也不能创建索引,而物化视图会把视图里查询出来的数据在 数据库 上建立快照,它和物理表一样,可以创建 索引,主键约束等等,性能会有质的提升,但是其有缺点,会占用,可以设置它定时自动更新一次,也可以手动更新,当然也是可以设置及时更新的,但是会拉慢基表的增删改查操作,在这里我只讲思路,具体的话大家可以自己去研究。

--创建物化视图,每天晚上22:00:00自动更新
create materialized view VM_PSNPERSONINFO 
refresh force on demand start with sysdate next to_date( concat( to_char( sysdate+1,'dd-mm-yyyy'),' 22:00:00'),'dd-mm-yyyy hh24:mi:ss')
SELECT dt.personid, c.employeeid,d.unitcode,d.unitname,d.label,
       dt.unitid,dt.startdate,dt.enddate
  FROM (
         SELECT DISTINCT b.personnelid personid,SUBSTR (a.effectdate, 1, 10) startdate,
         MIN (CASE WHEN a.effectdate < b.effectdate THEN b.effectdate ELSE N'9999-99-99' END) AS enddate,
         MIN (a.adjustresult) unitid
         FROM psnadjust a LEFT JOIN psnadjust b
         ON a.personnelid = b.personnelid
         WHERE a.adjusttype = '2' AND b.adjusttype = '2'
         GROUP BY b.personnelid, a.effectdate
 
推荐文章
气宇轩昂的蜡烛  ·  开始在 WSL 上使用 Git | Microsoft Learn
1 年前
高大的回锅肉  ·  python交流论坛推荐,python技术交流论坛_python ai 论坛-CSDN博客
1 年前
挂过科的烤面包  ·  输出流转输入流_51CTO博客_java输出流转输入流
2 年前
豪气的电脑桌  ·  Hikari 数据源参数配置描述 - 简书
2 年前
不羁的松树  ·  SSIS 目录 - SQL Server Integration Services (SSIS) | Microsoft Learn
2 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号