对于 单表的
视图,
插入/修改
数据是没有问题的。 (只要你不做特别的设置)\x0d\x0a\x0d\x0a对于多表的视图, *** 作的时候,会存在一定的问题。\x0d\x0a\x0d\x0a下面是一个例子:\x0d\x0a\x0d\x0a1>CREATE VIEW v_main_sub AS\x0d\x0a2>SELECT\x0d\x0a3> test_main.id AS main_id,\x0d\x0a4> test_main.value AS main_value,\x0d\x0a5> test_sub.id AS sub_id,\x0d\x0a6> test_sub.value AS sub_value\x0d\x0a7>FROM\x0d\x0a8> test_main, test_sub\x0d\x0a9>WHERE\x0d\x0a10> test_main.id = test_sub.main_id\x0d\x0a11>go\x0d\x0a\x0d\x0a1>SELECT * FROM v_main_sub\x0d\x0a2>go\x0d\x0amain_id main_value sub_id sub_value\x0d\x0a----------- ---------- ----------- ----------\x0d\x0a 1 ONE 1 ONEONE\x0d\x0a 2 TWO 2 TWOTWO\x0d\x0a\x0d\x0a(2 行受影响)\x0d\x0a\x0d\x0a1>UPDATE v_main_sub\x0d\x0a2>SET main_value='ONX'\x0d\x0a3>WHERE main_id = 1\x0d\x0a4>go\x0d\x0a\x0d\x0a(1 行受影响)\x0d\x0a\x0d\x0a1>UPDATE v_main_sub\x0d\x0a2>SET sub_value='ONXONX'\x0d\x0a3>WHERE main_id = 1\x0d\x0a4>go\x0d\x0a\x0d\x0a(1 行受影响)\x0d\x0a\x0d\x0a1>DELETE FROM v_main_sub WHERE main_id = 1\x0d\x0a2>go\x0d\x0a消息 4405,级别 16,状态 1,服务器 GMJ-PC\SQLEXPRESS,第 1 行\x0d\x0a视图或函数 'v_main_sub' 不可更新,因为修改会影响多个基表。\x0d\x0a\x0d\x0a-- 这个触发器, 只测试输出, 不删除数据。\x0d\x0a1>CREATE TRIGGER v_main_sub_trigger\x0d\x0a2>ON v_main_sub\x0d\x0a3>INSTEAD OF DELETE\x0d\x0a4>AS\x0d\x0a5>DECLARE\x0d\x0a6> @main_id INT,\x0d\x0a7> @sub_id INT\x0d\x0a8>BEGIN\x0d\x0a9> SELECT @main_id=main_id, @sub_id=sub_id FROM deleted\x0d\x0a10>\x0d\x0a11>\x0d\x0a12> PRINT(@main_id)\x0d\x0a13> PRINT(@sub_id)\x0d\x0a14>END\x0d\x0a15>go\x0d\x0a\x0d\x0a1>DELETE FROM v_main_sub WHERE main_id = 1\x0d\x0a2>go\x0d\x0a1\x0d\x0a1\x0d\x0a\x0d\x0a(1 行受影响)\x0d\x0a1>DELETE FROM v_main_sub WHERE sub_id = 1\x0d\x0a2>go\x0d\x0a1\x0d\x0a1\x0d\x0a\x0d\x0a(1 行受影响)\x0d\x0a\x0d\x0a对于多表关联的视图, 删除的时候,需要人为的去判断\x0d\x0a例如当 主表 和 子表,都只有一条记录的情况下。\x0d\x0a无法判断 本次删除, 是要删除掉一个子表的记录,留下主表的。\x0d\x0a还是 主表 子表的数据,一同删除。视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。
当建立视图时使用的表中的数据发生了改变后,视图中的数据也会发生相应的改变,视图本身是不能执行添加,删除,修改的!
如果要插入新数据的话,建议使用触发器,在视图相对应的各表中插入数据。视图中自然更新。
视图是由多个表,根据某种关系连接在一起的记录集合,如果要插入数据,应该根据逻辑关系和主外键关系,对表插入数据。
比如说
学校表,班级表,学生表,其关系假设为
学校表---->班级表---->学生表
从前到后为一对多的关系,即前一个是后一个的主表,后一个是前一个的从表
当建立学生视图,此时要插入学生记录,则直接插入学生表,要插入班级记录,则直接插入到班级表,前提是,主表必须先有记录,从表才能插入
评论列表(0条)