SQL Server视图数据更改的常见限制条件

数据库 SQL Server
用户更新视图中的数据时,是有一些限制条件的,下面就让我们来一起了解一下SQL Server视图数据更改的常见限制条件。

SQL Server视图相信大家都比较熟悉了,下面就为您介绍SQL Server视图数据更改的常见限制条件,如果您对SQL Server视图方面感兴趣的话,不妨一看。

当用户更新视图中的数据时,其实更改的是其对应的数据表的数据.无论是对视图中的数据进行更改,还是在视图中插入或者删除数据,都是类似的道理.但是,不是所有SQL Server视图都可以进行更改.如下面的这些视图,在SQL Server数据库中就不能够直接对其内容进行更新,否则,系统会拒绝这种非法的操作.

(1) Group By子句

如在一个SQL Server视图中,若采用Group By子句,对视图中的内容进行了汇总。则用户就不能够对这张视图进行更新。这主要是因为采用Group By子句对查询结果进行汇总在后,视图中就会丢失这条纪录的物理存储位置。如此,系统就无法找到需要更新的纪录。若用户想要在视图中更改数据,则数据库管理员就不能够在视图中添加这个Group BY分组语句。

(2) Distinct关键字

如不能够使用Distinct关键字。这个关键字的用途就是去除重复的纪录。如没有添加这个关键字的时候,视图查询出来的纪录有250条。添加了这个关键字后,数据库就会剔除重复的纪录,只显示不重复的50条纪录。此时,若用户要改变其中一个数据,则数据库就不知道其到底需要更改哪条纪录。因为视图中看起来只有一条纪录,而在基础表中可能对有的纪录有几十条。为此,若在视图中采用了Distinct关键字的话,就无法对视图中的内容进行更改。

(3) AVG、MAX等函数

如果在视图中有AVG、MAX等函数,则也不能够对其进行更新。如在一张视图中,其采用了SUN函数来汇总员工的工资时,此时,就不能够对这张表进行更新。这是数据库为了保障数据一致性所添加的限制条件。

小結: 可见,试图虽然方便、安全,但是,其仍然不能够代替表的地位。当需要对一些表中的数据进行更新时,我们往往更多的通过对表的操作来完成。因为对视图内容进行直接更改的话,需要遵守一些限制条件。在实际工作中,更多的处理规则是通过前台程序直接更改后台基础表。至于这些表中数据的安全性,则要依靠前台应用程序来保护。确保更改的准确性、合法性。

 

 

 

【编辑推荐】

带您了解SQL Server分页查询语句

使用SQL Server查询语句实现简单查询

SQL Server连接错误的处理方法

SQL Server管理相关的注册表技巧

SQL Server服务器角色简介

责任编辑:段燃 来源: 互联网
相关推荐

2010-11-12 11:36:29

SQL Server视

2011-03-21 10:26:10

SQL Server视图管理

2009-01-14 10:26:34

SQL Server视图管理限制条件

2010-11-12 11:19:19

SQL Server视

2010-09-27 09:54:26

Sql Server视

2011-04-02 17:21:29

sql server视图

2010-09-13 11:09:34

SQL SERVER分

2010-09-13 14:35:58

sql server端

2010-11-11 17:20:51

SQL Server创

2010-07-14 10:11:30

SQL Server系

2010-11-10 09:44:31

SQL Server端

2010-07-19 09:31:53

SQL Server系

2010-07-19 16:36:13

SQL Server视

2010-07-12 10:34:58

SQL Server视

2010-07-07 13:18:13

SQL Server视

2010-11-11 17:15:13

SQL Server视

2010-11-11 16:59:59

SQL Server视

2010-12-17 09:11:41

SQL Server

2012-04-13 13:26:30

SQL Server

2009-07-02 12:57:00

SQL Server视
点赞
收藏

51CTO技术栈公众号