机房重构——视图,机房重构
视图、存储过程、触发器等等早就听说过,却没有真正接触过,一直处在一个以后再说的状态中,逃是逃不掉了。
机房重构,重构出了什么?留着这个疑问。重构完以后再做总结。
视图:在SQL中,外模式一级数据结构的基本单位是视图,就是从若干个基本表和(或)其他视图构造出来的表。其实就是一张虚表。
注意:在使用视图的时候,应当提前设置好关联表的主外键。
在机房收费系统里功能之一,学生查看余额时,用到了两张表的内容,Card表里的状态和余额,其他信息都来自学生表。
视图的创建和删除:
方法一:使用SQL语句创建视图
创建:
'CREATE VIEW<视图名>(<列表序列>)AS<SELECT查询语句> Create VIEW V_stuCard (CardNo,StudentNo,StudentName,Department,Grade,Class,Exlpain,Cstatuss,Cash) as Select T_Student.StudentNo ,T_Student .StudentName ,T_Student .Department ,T_Student .Grade ,T_Student .Class ,T_Student .Explain ,T_card.CardNo ,T_card.Cash ,T_Card .CStatus From T_Student ,T_Card Where T_Student .CardNo =T_Card .CardNo删除:
'删除:DROP VIEW<视图名> DROP VIEW V_stuCard
1、新建视图,右键视图新建
2、添加需要的表
3、确定之后选择字段,然后在勾选出每个表我们需要的字段就可以啦。
删除是也可以之间右击删除,很方便。
在D层编写代码,查询语句和查询表是一样的,只是把表名称改为视图名称就可以了。如上:"Select * from V_stuCard where CardNo=@CardNo"
为什么要使用视图呢?视图把我们需要的数据有机的结合到了一起,如果我们需要好几个表里的数据,还得查好几个表,让自己的代码很沉重,使用视图,不仅减少代码,还可以让我们只写一条查询语句就OK啦。
总结:个人认为,虽然方法二简单,实现容易,但是还是建议使用SQL语句创建,应该多熟悉一下对SQL语句的使用。
答案是C
视图是基于数据表的一种查询窗口。怎么可能在这种查询窗口中再建数据表呢?
就像你可以在房子上开窗,但你不能在窗子上盖个房子吧?
我觉得应该是ABCD都选
参考:
* 简单性。看到的就是需要的。视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。
* 安全性。通过视图用户只能查询和修改他们所能见到的数据。数据库中的其它数据则既看不见也取不到。数据库授权命令可以使每个用户对数据库的检索限制到特定的数据库对象上,但不能授权到数据库特定行和特定的列上。通过视图,用户可以被限制在数据的不同子集上:
使用权限可被限制在基表的行的子集上。
使用权限可被限制在基表的列的子集上。
使用权限可被限制在基表的行和列的子集上。
使用权限可被限制在多个基表的连接所限定的行上。
使用权限可被限制在基表中的数据的统计汇总上。
使用权限可被限制在另一视图的一个子集上,或是一些视图和基表合并后的子集上。
* 逻辑数据独立性。视图可帮助用户屏蔽真实表结构变化带来的影响。
二、视图的优点
(1)视图能简化用户的操作
(2)视图机制可以使用户以不同的方式查询同一数据
(3)视图对数据库重构提供了一定程度的逻辑独立性
(4)视图可以对机密的数据提供安全保护
三、视图的安全性
视图的安全性可以防止未授权用户查看特定的行或列,是用户只能看到表中特定行的方法如下:
1 在表中增加一个标志用户名的列;
2 建立视图,是用户只能看到标有自己用户名的行;
3 把视图授权给其他用户。
四、逻辑数据独立性
视图可以使应用程序和数据库表在一定程度上独立。如果没有视图,应用一定是建立在表上的。有了视图之后,程序可以建立在视图之上,从而程序与数据库表被视图分割开来。视图可以在以下几个方面使程序与数据独立:
1 如果应用建立在数据库表上,当数据库表发生变化时,可以在表上建立视图,通过视图屏蔽表的变化,从而应用程序可以不动。
2 如果应用建立在数据库表上,当应用发生变化时,可以在表上建立视图,通过视图屏蔽应用的变化,从而使数据库表不动。
3 如果应用建立在视图上,当数据库表发生变化时,可以在表上修改视图,通过视图屏蔽表的变化,从而应用程序可以不动。
4 如果应用建立在视图上,当应用发生变化时,可以在表上修改视图,通过视图屏蔽应用的变化,从而数据库可以不动。
五、视图的书写格式
CREATE VIEW <视图名>[(列名组)]
AS <子查询>
DROP VIEW <索引名>
注意:视图可以和基本表一样被查询,但是利用视图进行数据增,删,改操作,会受到一定的限制。
(1)由两个以上的基本表导出的视图
(2)视图的字段来自字段表达式函数
(3)视图定义中有嵌套查询
(4)在一个不允许更新的视图上定义的视图...余下全文>>