通过视图来访问数据其优点是非常明显的如可以起到数据保密保证数据的逻辑独立性简化查询操作等等
但是话说回来SQL Server数据库中的视图并不是万能的他跟表这个基本对象还是有重大的区别在使用视图的时候需要遵守四大限制
限制条件一视图数据的更改
当用户更新视图中的数据时其实更改的是其对应的数据表的数据无论是对视图中的数据进行更改还是在视图中插入或者删除数据都是类似的道理但是不是所有视图都可以进行更改如下面的这些视图在SQL Server数据库中就不能够直接对其内容进行更新否则系统会拒绝这种非法的操作
如在一个视图中若采用Group By子句对视图中的内容进行了汇总则用户就不能够对这张视图进行更新这主要是因为采用Group By子句对查询结果进行汇总在后视图中就会丢失这条纪录的物理存储位置如此系统就无法找到需要更新的纪录若用户想要在视图中更改数据则数据库管理员就不能够在视图中添加这个Group BY分组语句
如不能够使用Distinct关键字这个关键字的用途就是去除重复的纪录如没有添加这个关键字的时候视图查询出来的纪录有条添加了这个关键字后数据库就会剔除重复的纪录只显示不重复的条纪录此时若用户要改变其中一个数据则数据库就不知道其到底需要更改哪条纪录因为视图中看起来只有一条纪录而在基础表中可能对有的纪录有几十条为此若在视图中采用了Distinct关键字的话就无法对视图中的内容进行更改
如果在视图中有AVGMAX等函数则也不能够对其进行更新如在一张视图中其采用了SUN函数来汇总员工的工资时此时就不能够对这张表进行更新这是数据库为了保障数据一致性所添加的限制条件
可见试图虽然方便安全但是其仍然不能够代替表的地位当需要对一些表中的数据进行更新时我们往往更多的通过对表的操作来完成因为对视图内容进行直接更改的话需要遵守一些限制条件在实际工作中更多的处理规则是通过前台程序直接更改后台基础表至于这些表中数据的安全性则要依靠前台应用程序来保护确保更改的准确性合法性
限制条件二定义视图的查询语句中不能够使用某些关键字
我们都知道视图其实就是一组查询语句组成或者说视图是封装查询语句的一个工具在查询语句中我们可以通过一些关键字来格式化显示的结果如我们在平时工作中经常会需要把某张表中的数据跟另外一张表进行合并此时数据库管理员就可以利用Select Into语句来完成先把数据从某个表中查询出来然后再添加到某个表中
当经常需要类似的操作时我们是否可以把它制作成一张视图每次有需要的时候只需要运行这个视图即可而不用每次都进行重新书写SQL代码不过可惜的是结果是否定的在SQL Server数据库的视图中是不能够带有Into关键字如果要实现类似的功能只有通过函数或者过程来实现
另外跟Oracle数据库不同的是在微软的SQLServer数据库中创建视图的时候还有一个额外的限制就是不能够在创建视图的查询语句中使用order by排序语句这是一个很特殊的规定一些Oracle的数据库管理员在使用SQL Server数据库创建视图的时候经常会犯类似的错误他们就搞不明白为什么Oracle数据库中可行但是在微软的数据库中则行不通呢?这恐怕只有微软数据库产品的设计者才能够回答的问题总之我们要记住的就是在SQLServer数据库中建立视图时查询语句中不能够包含Order By语句
限制条件三要对某些列取别名并保证列名的唯一
在表关联查询的时候当不同表的列名相同时只需要加上表的前缀即可不需要对列另外进行命名但是在创建视图时就会出现问题数据库会提示duplicate column name的错误提示警告用户有重复的列名有时候用户利用Select语句连接多个来自不同表的列若拥有相同的名字则这个语句仍然可以执行但是若把它复制到创建视图的窗口创建视图时就会不成功
查询语句跟创建视图的查询语句还有很多类似的差异如有时候我们在查询语句中可能会比较频繁的采用一些算术表达式;或者在查询语句中使用函数等等在查询的时候我们可以不给这个列取名数据库在查询的时候会自动给其命名但是在创建视图时数据库系统就会给你出难题系统会提醒你为列取别名
从以上两个例子中我们可以看出虽然视图是对SQL语句的封装但是两者仍然有差异创建视图的查询语句必须要遵守一定的限制如要保证视图的各个列名的唯一;如果自阿视图中某一列是一个算术表达式函数或者常数的时候要给其取名字等等
限制条件四权限上的双重限制
为了保障基础表数据的安全性在视图创建的时候其权限控制比较严格
一方面若用户需要创建视图则必须要有数据库视图创建的权限这是视图建立时必须遵循的一个基本条件如有些数据库管理员虽然具有表的创建修改权限;但是这并不表示这个数据库管理员就有建立视图的权限恰恰相反在大型数据库设计中往往会对数据库管理员进行分工建立基础表的就只管建立基础表;负责创建视图的就只有创建视图的权限
其次在具有创建视图权限的同时用户还必须具有访问对应表的权限如某个数据库管理员已经有了创建视图的权限此时若其需要创建一张员工工资信息的视图还不一定会成功这还要这个数据库管理员有美誉跟工资信息相关的基础表的访问权限如建立员工工资信息这张视图一共涉及到五张表则这个数据库管理员就需要拥有者每张表的查询权限若没有的话则建立这张视图就会以失败告终
第三就是视图权限的继承问题如上面的例子中这个数据库管理员不是基础表的所有者但是经过所有者的授权他就可以对这个基础表进行访问就可以以此为基础建立视图但是这个数据库管理员有没有把对这个基础表的访问权限再授权给其他人呢?如他能否授权给A用户访问员工考勤信息表呢?答案是不一定默认情况下数据库管理员不能够再对其他用户进行授权但是若基础表的所有者把这个权利给了数据库管理员之后则他就可以对用户进行重新授权让数据库管理员可以给A用户进行授权让其可以进行相关的操作
可见视图虽然灵活安全方便但是其仍然有比较多的限制条件根据笔者的经验一般在报表表单等等工作上采用视图会更加的合理因为其SQL语句可以重复使用而在基础表更新上包括纪录的更改删除或者插入上往往是直接对基础表进行更新对于一些表的约束可以通过触发器规则等等来实现;甚至可以通过前台SQL语句直接实现约束作为数据库管理员要有这个能力能够判断在什么时候使用视图什么时候直接调用基础表