之前一直都不知道VIEW有什么作用,写程序的时候也很少遇到过,复习SQL语句的时候碰到了,就记录下来吧。
什么是视图?
在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表。
视图包含行和列,就像一个真实的表。视图中的字段就是来自一个或多个数据库中的真实的表中的字段。我们可以向视图添加 SQL 函数、WHERE 以及 JOIN 语句,我们也可以提交数据,就像这些来自于某个单一的表。
注释:数据库的设计和结构不会受到视图中的函数、where 或 join 语句的影响。
SQL CREATE VIEW 语法
1 CREATE VIEW view_name AS 2 SELECT column_name(s) 3 FROM table_name 4 WHERE condition
注释:视图总是显示最近的数据。每当用户查询视图时,数据库引擎通过使用 SQL 语句来重建数据。
查询:
1 SELECT * FROM view_name WHERE condition
SQL 更新视图
你可以使用下面的语法来更新视图:
1 CREATE OR REPLACE VIEW view_name AS 2 SELECT column_name(s) 3 FROM table_name 4 WHERE condition
一次只能用CREATE或REPLACE,重新建一个(CREATE)也就是更新
SQL 撤销视图
您可以通过 DROP VIEW 命令来删除视图。
1 DROP VIEW view_name
View具体能干些什么呢?
- simplify data access for query writers. (简化数据访问)
- managing security and protecting sensitive data.(权限管理和保护敏感数据)
- grant permissions exclusively to views, rather than to the underlying tables (不直接分配表的权限给用户,用view来替代)
- expose only those columns that you wish the end user to see (可以让终端用户只看到他们要看的列)
- allow direct data updates. (允许更新数据)
View 的种类?
- Regular View (普通的view,我的理解就是最简单的view定义)
- 不要嵌套view (例如用一个view 去叫另外一个view)
- 如果可以尽量用stored procedure来代替view.(和view对比,每一次访问view,这个view的execution plan就会重新编译一次)
- Indexed View (索引的view,和table差不多,先定义普通view,然后再加上clustered index和non-clustered index. 注意:clustered index只能有一个)
- Distributed Partitioned View (分布式的view,这种view用UNION ALL 把几个不同的SQL Server的table结合在一起生成一个单独的table)
在创建view的时候有几条规则需要注意一下
第一 select表达式最多只能定义1024个列
第二 INTO, OPTION, COMPUTE, COMPUTE BY 还有引用其他表格变量都不能用
第三 ORDER BY不能直接用,除非和TOP一起用