什么是数据库视图怎样去理解它

什么是数据库视图怎样去理解它,第1张

数据库是依照某种数据模型组织起来并存放二级存储器中的数据集合。这种数据集合具有如下特点:尽可能不重复,以最优方式为某个特定组织的多种应用服务,其数据结构独立于使用它的应用程序,对数据的增、删、改和检索由统一软件进行管理和控制。从发展的历史看,数据库是数据管理的高级阶段,它是由文件管理系统发展起来的。

数据库的基本结构分三个层次,反映了观察数据库的三种不同角度。

(1)物理数据层。它是数据库的最内层,是物理存贮设备上实际存储的数据的集合。这些数据是原始数据,是用户加工的对象,由内部模式描述的指令 *** 作处理的位串、字符和字组成。

(2)概念数据层。它是数据库的中间一层,是数据库的整体逻辑表示。指出了每个数据的逻辑定义及数据间的逻辑联系,是存贮记录的集合。它所涉及的是数据库所有对象的逻辑关系,而不是它们的物理情况,是数据库管理员概念下的数据库。

(3)逻辑数据层。它是用户所看到和使用的数据库,表示了一个或一些特定用户使用的数据集合,即逻辑记录的集合。

数据库不同层次之间的联系是通过映射进行转换的。数据库具有以下主要特点:

(1)实现数据共享。数据共享包含所有用户可同时存取数据库中的数据,也包括用户可以用各种方式通过接口使用数据库,并提供数据共享。

(2)减少数据的冗余度。同文件系统相比,由于数据库实现了数据共享,从而避免了用户各自建立应用文件。减少了大量重复数据,减少了数据冗余,维护了数据的一致性。

(3)数据的独立性。数据的独立性包括数据库中数据库的逻辑结构和应用程序相互独立,也包括数据物理结构的变化不影响数据的逻辑结构。

(4)数据实现集中控制。文件管理方式中,数据处于一种分散的状态,不同的用户或同一用户在不同处理中其文件之间毫无关系。利用数据库可对数据进行集中控制和管理,并通过数据模型表示各种数据的组织以及数据间的联系。

(5)数据一致性和可维护性,以确保数据的安全性和可靠性。主要包括:①安全性控制:以防止数据丢失、错误更新和越权使用;②完整性控制:保证数据的正确性、有效性和相容性;③并发控制:使在同一时间周期内,允许对数据实现多路存取,又能防止用户之间的不正常交互作用;④故障的发现和恢复:由数据库管理系统提供一套方法,可及时发现故障和修复故障,从而防止数据被破坏

基本表是数据库中用来存储数据的对象,是有结构的数据的集合,是整个数据库系统的基础。数据在表中式按行和列的格式组织排列的。

视图是计算机数据库中的一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。

基本表、视图区别为:存在不同、存储内容不同、 *** 作不同。视图是由一个或几个基本表导出形成的虚表。

一、存在不同

1、基本表:基本表是本身独立存在的表。

2、视图:视图本身不存在独立存储在数据库中,是一个虚表。

二、存储内容不同

1、基本表:基本表存储的内容是实际的数据。

2、视图:视图存储的内容只有存储定义,不存放实际数据。

三、 *** 作不同

1、基本表: *** 作者可以对基本表进行增删改查四种 *** 作。

2、视图: *** 作者只可以对视图进行查 *** 作,不能进行增删改 *** 作。

参考资料来源:

百度百科——表

百度百科——视图

是从一个或多个表或视图导出的表。视图与表有时为与视图区别,也称表为基本表不同,视图是一个虚表,即视图所对应的数据不进行实际存储,数据库中只存储视图的定义,在对视图的数据进行 *** 作时,系统根据视图的定义去 *** 作与视图相关联的基本表。

1、简单性,看到的就是需要的。视图不仅可以简化用户对数据的理解,也可以简化他们的 *** 作。被经常使用的查询可以被定义为视图,从而使得用户不必为每次 *** 作指定全部的条件。

2、安全性,通过视图用户只能查询和修改他们所能见到的数据。数据库中的其它数据则既看不见也取不到。数据库授权命令可以使每个用户对数据库的检索限制到特定的数据库对象上,但不能授权到数据库特定行和特定的列上。

数据库对象定义了数据库内容的结构。它们包含在数据库项目中,数据库项目还可以包含数据生成计划和脚本。在“解决方案资源管理器”中,数据库对象在文件中定义,并在数据库项目中的“架构对象”子文件夹下根据类型分组。使用数据库对象时,您可能会发现使用名为“架构视图”的数据库对象视图会更加直观。在“架构视图”中,您可以看到按类别划分的数据库对象。如果数据库项目中的文件标记为“生成”Build Type,则将分析该文件以查看它是否包含数据库对象定义。数据库项目中包含的标记为其他 Build Type 的文件不被视为包含数据库对象且不在“架构视图”中显示的文件。

@@@还是看这里吧很详细的

问题一:什么是视图定义 视图是从一个或多个表或视图中导出的表,其结构和数据是建立在对表的查询基础上的。和表一样,视图也是包括几个被定义的数据列和多个数据行,但就本质而言这些数据列和数据行来源于其所引用的表。

所以视图不是真实存在的基础表而是一张虚表,视图所对应的数据并不实际地以视图结构存储在数据库中,而是存储在视图所引用的表中。

视图一经定义便存储在数据库中,与其相对应的数据并没有像表那样又在数据库中再存储一份,通过视图看到的数据只是存放在基本表中的数据。对视图的 *** 作与对表的 *** 作一样,可以对其进行查询、修改(有一定的限制)、删除。

当对耽过视图看到的数据进行修改时,相应的基本表的数据也要发生变化,同时,若基本表的数据发生变化,则这种变化也可以自动地反映到视图中。

视图有很多优点,主要表现在:

视点集中

简化 *** 作

定制数据

合并分割数据

安全性

如果你要创建一个视图,为其指定一个名称和一个查询即可。Microsoft SQL Server只保存视图的元数据(metadata),用于描述这个对象,以及它所包含的列、安全、依赖等。当你查询视图时,无论是获取数据还是修改数据,查询处理器(query processor)都会用视图定义代替视图引用。也就是说,查询处理器展开视图定义并生成访问基对象(underlying objects)的执行计划。

视图在数据库中发挥着重要的作用。视图的重要用途之一便是被用作一个抽象装置(abstraction mechani )。例如,在适当时利用视图你可以很容易地为基础数据提供或多或少的规范化映像(normalized picture),这样就不用更改实际数据的规范化(normalization)。通过应用模块化的方法(逐步解决复杂问题),可以简化解决方案。可以利用视图访问经过筛选和处理的数据,而不是直接对基表(base table)进行 *** 作(让视图的架构和基对象的架构相同),可以把视图作为一个安全层(security layer)(在一定程度上)。

如果在视图上创建索引,它在提高性能方面也发挥着重要作用。在视图上创建聚集索引(clustered index)会让它的数据真正地保存在磁盘上,而不再是虚拟的数据。我会在本章专门用一节介绍索引视图。现在,我们先来关注没有索引的视图,它们通常没有特定的性能影响,包括消极的或积极的。

与其他的表表达式(如派生表、公用表表达式,或内联表值用户定义函数[inline table-valued user-defined function,UDF])一样,视图的查询定义必须满足3个条件:

不能在查询定义中使用ORDER BY,除非定义中包含TOP或FOR XML说明符。

所有的结果列必须有名称。

所有结果列的名称必须是唯一的。

定义视图的查询中在没有TOP或FOR XML说明符的情况下不能包含ORDER BY子句,这是因为视图被认为表示一个表。表是一个逻辑实体,它的行没有顺序,不同于游标,游标是一个物理对象,它可以对行排序。表中的所有列必须有名称,且名称必须是唯一的,这一点勿庸置疑。为视图的目标列指定名称有两种方法,可以在视图名称后面的圆括号内指定,也可以用每个表达式后面的别名作为列名称。

来看一个示例,运行下面的代码创建VcustsWithOrders视图。

SET NOCOUNT ON;USE Northwind;GOIF OBJECT_ID(‘dboVcustsWithOrders’) IS NOT NULLDROP VIEW dboVcust>>

问题二:机械制图里面向视图是什么意思 向视图,是从图中“箭头”指向“看”过去,所得到的视图,也可以是局部视图。

问题三:什么叫视图? 用正投影法所绘制出的机件的多面正投影图,为视图。

分为:主视图 自机件的前方

俯视图 自机件的上方

左视图 自机件的左方

右视图 自机件的右方

仰视图罚 自机件的下方

后视图 自机件的后方

问题四:java中的视图是什么意思 比如set视图和set 有什么区别??? 对于Map接口而言,JDK源码中将其分为三种视图,其实就是三种以某种 存储值的表现形式。分别为Set :用以存储Map的key;Collection 用以存储Map的value;而Set>是存储key-value对(键-值对)。Set视图就是使用Set 存储的Vew,Set 特点就是不可重复。

问题五:什么叫基本表?什么是视图?二者的区别和联系是什么? 以下是我个人的理解,不妥之处请各位指点:

基本表是指数据库中‘实在’的表格,它存储的就是数据本身;

视图可以理解为保存后的查询,它保存的是‘实在’表格经查询后的结果。基本表是视图的来源和基础,视图丰富了基本表的表达。

问题六:在sql数据库里的视图是什么意思,怎么理解? 视图作用比较广的,可能楼主对数据库还不是很了解,首先视图可以将不同表中的数据通过关联实现多表数据输出,比如说,有一个类型表 uType,有字段tId,tName,有个产品表 uProduct,有字段pId,pName,tId,此时你可以通过建立一张视图vProduct将产品表和产品类型一起输出

SE工ECT ppId AS 产品编号,ppName AS 产品名称,ttId AS 产品类型编号,ttId AS 产品类型编号

FROM uProduct AS p INNER JOIN uType AS t ON ptId = ttId;

这样就可以在程序里使用

SELECT FROM vProduct 来做产品资料的查询了

它可以减少我们编码的工作量,也方便维护。

问题七:五视图是什么意思 就是同时显视五个视图

以上就是关于什么是数据库视图怎样去理解它全部的内容,包括:什么是数据库视图怎样去理解它、什么叫基本表什么是视图二者的区别和联系是什么、数据库中视图的作用等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10162801.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存