㈠ 什么视图允许更新操作,什么视图不允许更新操作。 sql题
(1) 若视图是基于多个表使用联接操作而导出的,那么对这个视图执行更新操作时,每次只能影响其中的一个表。
(2) 若视图导出时包含有分组和聚合操作,则不允许对这个视图执行更新操作。
(3) 若视图是从一个表经选择、投影而导出的,并在视图中包含了表的主键字或某个候选键,这类视图称为‘行列子集视图’。对这类视图可执行更新操作。
㈡ 视图在什么情况下不能更新举个例子
视图中如果使用了 AVG、max等 函数,即有对数据的二次加工性质的操作时,不允许更新;
而简单的SQL形成的视图的灵活性则没有限制 !
㈢ sql 中在什么情况下使用视图,有什么好处
什么情况下会用到视图?
比如说一个比较复杂的查询不想每次都写很多语句,就可以写个视图。下次查询的时候是需要使用select * from视图名就可以了。
或者给特定用户开放某些表的读取权限,但要加一些行和列的限制,也可以写个视图。
视图的好处,可以主要分为四点:
第一点: 使用视图,可以定制用户数据,聚焦特定的数据。
解释:
在实际过程中,公司有不同角色的工作人员。
以销售公司为例:,采购人员,可以需要一些与其有关的数据,而与他无关的数据,对没有任何意义,我们可以根据这一实际情况,专门为采购人员创建一个视图,以后他在查询数据时,只select*fromview_caigou就可以了。
第二点:使用视图,可以简化数据操作。
解释:
在使用查询时,在很多时候要使用聚合函数,同时还要显示其它字段的信息,可能还会需要关联到其它表,这时写的语句可能会很长,如果这个动作频繁发生的话,则可以创建视图。以后要用的话,只需要select*fromview1就可以了。
第三点:使用视图,基表中的数据就有了一定的安全性
因为视图是虚拟的,物理上是不存在的,只是存储了数据的集合,故可以将基表中重要的字段信息,可以不通过视图给用户,视图是动态的数据的集合,数据是随着基表的更新而更新。同时,用户对视图,不可以随意的更改
和删除,可以保证数据的安全性。
第四点:可以合并分离的数据,创建分区视图
随着社会的发展,公司业务量不断的扩大,一个大公司,下属都设有很多的分公司,为了管理方便,需要统一表的结构,定期查看各公司业务情况,而分别看各个公司的数据很不方便,没有很好的可比性,如果将这些数据合并为一个表格里,就方便多了,这时就可以使用union关键字,将各分公司的数据合并为一个视图。
㈣ 视图数据在什么情况下可以修改
视图是不能修改数据的。只有在用到多个关联表查询的时候可能用到视图。查询的时候直接从建立好的视图中获得数据,不必使用inner
join等
SQL语句
来“手动”的从多个表中查询内容了。
视图是建立在多个表基础之上的,如果你要修改数据,只能修改这些关联的表。修改后的数据会自动从视图中获得。
㈤ SQL语句查询多个表,得到的记录集为什么不能新增。
w作为一个视图,如果数据来源来源于两张表,那么是不能进行更新的,因为来源于两张表的数据同步起来很容易出错
但数据来源于一张表的视图 可以做同步更新!
你可以试着把它做成两张表吧!
㈥ 关于sql2005问题 为什么我用视图去增加列的时候,不能增加not null的列。可以增加null列
视图,这是表(table)啊
你想啊,not null的意思是什么,不可为空啊,
你新增加的列,哪儿能有值呢?所以肯定为空啊;矛盾了,所以不能这么做。
2个办法试试:
1. 增加列的同时,指定列的默认值:alter table HTC add column Camera nchar(50) not null default('abc');
2. 将现有列中为空的值,都设置成默认值,然后再修改为not null;
update htc set camera = 'abc' where camera is null;
alter table HTC
alter column Camera nchar not null
㈦ sql怎么创建不可更新的视图
1L错误,如果视图只是单表组成的,是可以更新的. 但是你的视图是两个表得出的,里面有多表关联,这种情况是不能更新视图的. 如果要更新,建议使用触发器,分别更新单个表,从而达到相同的目的.
㈧ 在SQL 里哪些视图可以更新,哪些不可以更新。(要写500字的论文)希望提供全面一点的~
视图一般式可以更新的,但前提是不能有聚合函数或分组等。
在这个前提下:
1:简单视图
就是由一个表生成出来的视图,这种情况你更新她就和更新表一样
2:二次加工出来的简单视图
仍然是一个表出来的视图,但是视图中存在通过函数或计算二次加工出来的其他字段。更新的时候只要不更新这些加工出来的字段也是可以更新的。
3:组合视图
通过表之间关联联合等出来的复杂视图。这种视图更新的时候要注意你所更新的列要来自同一个表,也是可以更新的。
4:静态视图
这种视图等同于表可以直接更新,但是更新的数据尽在视图中反映出来,不反映到原表
5:其他视图
通过表函数等其他生成的更为复杂的视图。一般不可更新
㈨ SQL2005新建了一个视图为什么添加不成数据
视图只是表的映射而已。只能在表里面添加数据而在视图中显示出来,不能在视图中直接添加数据。
来,我手把手的教你