在一个项目的实际开发过程中牵涉到复杂业务的时候,我们不可避免的需要使用中间表来进行数据连接,有的同学就说了,我可以采用Hibernate进行主外键进行关联啊?多对多,多对一,一对一,等,采用主外键关联在数据的 *** 作过程中具有很强的耦合性,尤其对于需要经常删改数据表而言,我们是不建议采用主外键关联这种模式,那么,如果我们采用中间表的话,当数据过大在性能上又面临严峻考验,sql视图的出现,在解决中间表的业务逻辑上是不错的选择。ok,首先我们了解什么是视图?
视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。
视图是为了查询方便!也就是多个表的总结!但是不能对视图增删改!
在做数据库开发中使用视图的优点有:1.视图的好处就是在你做复杂的查询逻辑时可以简化你的思考过程。
2.用视图可以隐藏一定的信息,用过滤后查询出来的数据集组成视图 可以访问表中的子集,可以访问表中行的子集。
3.可以重命名列名。在表中有些列名定义没有代表意义,如列“abc”,为了让用户看到列名就可以知该列是什么数据,可以在组建视图时重命名列名。
4.可以快速访问两表或多表连接所组成的数据。 可以把一些多表的数据组合在一块,可以快速读取用聚合函数返回的结果集。
5.有了视图 程序可以建立视图上
6.可以合并分离的数据,创建分区视图 。当数据量大的时候,这时我们就可以使用union关键字, 将各分公司的数据合并为一个视图。
7.视图还可以用作跨表及跨域,在两台数据库之间做桥梁链接的作用。
总的说,视图可以提高安全性 可以提高查询速度。
缺点 在QL Server必须把视图的查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,
那么,即使是视图的一个简单查询,SQL Server也把它变成一个复杂的结合体,需要花费一定的时间。
在后期的维护上 数据库的表结构变了 也会影响视图的改变,维护繁琐。
所以在定义数据库的时候,要合理的使用视图。
视图的作用:1 简单性。看到的就是需要的。视图不仅可以简化用户对数据的理解,也可以简化他们的 *** 作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的 *** 作每次指定全部的条件。
2 安全性。视图使用户能以多种角度看待同一数据,视图使用户能以多种角度看待同一数据,当许多不同种类的用户共享同一数据库时,这种灵活性很重要
3 视图对重构数据库提供了一定程度的逻辑独立性
4 视图能够对机密数据提供安全保护,有了视图机制,就可以在设计数据可应用系统时,对不同的用户定义不同的视图,使机密数据不出现在不应看到这些数据的用户视图上
5 适当的利用视图可以更清晰的表达查询
如:社会保险基金表,可以用视图只显示姓名,地址,而不显示社会保险号和工资数等,另一原因是可使复杂的查询易于理解和使用。
使用视图可以实现下列任一或所有功能:
将用户限定在表中的特定行上。
例如,只允许雇员看见工作跟踪表内记录其工作的行。
将用户限定在特定列上。
例如,对于那些不负责处理工资单的雇员,只允许他们看见雇员表中的姓名列、办公室列、工作电话列和部门列,而不能看见任何包含工资信息或个人信息的列。
将多个表中的列联接起来,使它们看起来象一个表。
聚合信息而非提供详细信息。
例如,显示一个列的和,或列的最大值和最小值。
通过定义 SELECT 语句以检索将在视图中显示的数据来创建视图。SELECT 语句引用的数据表称为视图的基表。在下例中,pubs 数据库中的 TItleview 是一个视图,该视图选择三个基表中的数据来显示包含常用数据的虚拟表:
之后,可以用引用表时所使用的方法在语句中引用 TItleview。
一个视图可以引用另一个视图。例如,TItleview 显示的信息对管理人员很有用,但公司通常只在季度或年度财务报表中才公布本年度截止到现在的财政数字。可以建立一个视图,在其中包含除 au_ord 和 ytd_sales 外的所有 TItleview 列。使用这个新视图,客户可以获得已上市的书籍列表而不会看到财务信息:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)