首页 > 编程知识 正文

数据库系统的基本概念,关于数据库应用系统的概念

时间:2023-05-06 15:11:10 阅读:166442 作者:1562

在同一数据集内,不同的选择条件对应于不同的输出结果。 数据库是按数据结构组织、存储和管理数据的仓库。 程序和用户可以访问和修改作为数据存储灵魂的数据。

数据管理经历了人工管理、文件系统到数据库系统三个阶段。 数据库是具有逻辑关系和确定意义的数据的结合,可以克服传统文件组织产生的一系列问题,数据冗余小,关系数据库管理系统对信息查询具有较大的灵活性,由于设计简单,已成为实际系统

什么是触发? 触发器分为事前触发器和事后触发器。 有什么区别? 语句级触发器和行级触发器的区别是什么? 什么是索引? 什么是回滚数据备份? 有什么种类? 如果游标已满数据库日志,会发生什么情况? 你怎么判断? 谁是怎么将一行数据插入数据库的?

在实际的APP应用中,基本的数据库操作不能满足实际的需要。 随着数据表的增加、数据量的增加,数据库的效率和安全问题越来越突出,数据库中引入了触发器、游标、索引等

触发器是一种特殊类型的存储过程,由事件触发,而不是由程序调用或手动启动。 如果数据库有特殊操作,这些操作将由数据库中的事件触发,并且这些SQL语句会自动完成。 触发器可以保证数据的有效性和完整性,并完成比约束更复杂的数据约束。

根据SQL语句的不同,触发器可以分为:DML触发器和DLL触发器两种。

DML触发器是在当前数据库服务器上发生数据操作语言事件时执行的存储过程,有两种类型的触发器: After和Instead of。 After触发器将激活并启动,这是在记录更改后发生的一种触发器。 Instead of触发器在记录更改之前执行触发器自身定义的操作,而不是原始SQL语句的操作。 DLL触发器是响应数据定义语言事件时执行的存储过程。

触发器的主要作用在于以下方面:

(1)提高安全性

)2)利用触发器,记录变更及相关信息,跟踪用户数据库操作,实现审计

)3)维持在表制作时的宣言制约中不能实现的代入的完整性制约,监视数据库内的特定事件并应答

)4)实现复杂的、非标准的数据库相关完整性规则,同步实时分配表中的数据

)5)触发器是自动的,当对表中的数据进行某些更改时会激活。 例如,可以自动计算数据值,并在数据值满足某些要求时执行某些操作。 以某企业财务管理为例,当企业资金链不足,达到一定程度时,会发出警告信息。

本节显示了一个每周末更新数据表的触发器示例。 如果当前用户没有访问WEEKEND_UPDATE_OK表的权限,则必须再次授予该权限。

createorreplacetriggerupdata _ on _ weekends _ checkbeforeupdateofsalonempforeachrowdeclaremy _ countnumber (4); beginselectcount(u_name ) from weekend _ update _ okintomy _ countwhereu _ name=user _ name; ifmy _ count=0then raise _ application _ error (20508,' Update not allowed ' ); END IF; 结束; 引申:触发分为预触发和后触发,两者有什么区别? 语句级触发器和行级触发器的区别是什么? 事前触发发生在事件上

发生前验证一些条件或进行一些准备工作的事后触发发生在事件发生后,做好收尾工作,保证事务的完整性。 预触发器可以获取以前和新的字段值。 语句级触发器可以在语句执行之前或之后发生,但行级触发器会为每个受触发器影响的行触发。

索引是一种加速数据库查询的机制,它是通过尝试根据数据库中表或键字段的值按升序或降序排序而创建的对象。 当用户查询索引字段时,搜索操作将快速执行,并且索引使您可以在执行查询时快速找到所需的数据,而无需扫描整个表。 索引是与表或视图相关联的磁盘结构,用于对表或视图中的列值进行排序,从而加快从表或视图中检索行的速度,并将其转换为数据库中的信息,而无需在执行查询时扫描整个表

create unique clustered index PK_商品on商品(产品编号) withpad_index,fillfactor=10,drop_existing索引记录包含键值和逻辑指针。 创建索引时,会分配索引页。 在表中插入一行数据,在索引页中也插入一行索引记录。 索引记录包含的索引字段的值小于实际数据量,因此可以节省空间。

索引的类型有焦点索引和非焦点索引。 焦点索引是指表中行的物理顺序与键值的逻辑顺序相同,并且每个表只能有一个焦点索引。 焦点索引通常比非焦点索引提供更快的数据访问速度。 非焦点索引是数据存储和索引存储不在同一个位置。 索引中有一个指向数据存储位置的指针。 索引中的项目按索引之前的顺序存储,表中的信息按其他顺序存储。

建立索引可以大大提高系统的性能。 主要包括以下几个方面:

(1)通过建立唯一性索引,可以保证数据库表中各行数据的唯一性。

> (2)通过索引,可以大大加快数据的索引速度
(3)通过索引可以加速表和表之间的连接,从而有效实现数据的参考完整性
(4)在使用分组和排序子句进行数据检索时,可以显著减少查询中分组和排序的时间
(5)通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能

索引可以有效地提高查询效率,那为什么不将所有的列都建立索引呢?其实索引尽管可以带来方便,但并非越多越好,过多的索引页会带来许多不利的问题
(1)创建索引和维护索引要耗费时间、空间。当数据量比较小时,这种问题还不够突出;而当数据量比较大时,这种缺陷会比较明显,效率会非常低下
(2)除了数据表占数据空间外,每一个索引还需要占用一定的物理空间。如果要建立聚簇索引,那么需要的空间就会更大,从而造成不必要的空间浪费。
(3)当对表中的数据进行增加、删除和修改的时候,索引也要动态地维护,从而降低了数据的维护速度。

什么是回滚

为了保证在应用程序、数据库或系统出现错误后,数据库能够被还原,以保证数据库的完整性,所以需要进行回滚。回滚(rollback)就是在事务提交之前将数据库数据恢复到事务修改之前数据库数据状态。

回滚执行相反的操作,可以撤销错误的操作,从而保证数据的完整性。例如,用户A给用户B转账,在数据库中就需要给A与B的账户信息进行修改(update)操作,而这两条sql语句必须都执行或者都不执行。

注意回滚和撤销的区别。回滚是指将数据库的状态恢复到执行事务之前的状态,其中可能会使用UNDO日志进行回滚。撤销是一种记录日志的方式,并不是主要服务于事务回滚,而是主要用于系统从故障中恢复。例如,系统突然断电,系统要根据UNDO日志对未完成的事务进行处理,保证数据库的状态为执行这些事务前的状态。

数据备份有哪些种类

数据备份就是保存数据的备份,目的是为了预防灾难造成的数据损失。它一般分为完全备份、差异备份、事务日志备份、增量备份几大类。

(1)完全备份
是将数据库中的全部信息进行备份,它是恢复的基线,在进行完全备份时,不但备份数据库的数据文件、日志文件,还需要备份文件的存储位置信息以及数据库中的全部对象和相关信息。在对数据库进行完全备份时,所有未完成的事务或发生在备份过程中的事务都将被忽略,如果使用完全数据库备份类型,那么从开始备份到开始恢复这段时间内发生的任何针对数据库的修改都将无法恢复。所以,只有在一定的要求或条件下才使用这种备份类型。

(2)差异备份
是备份从最近的完全备份之后对数据所作的修改,它以完全备份为基准点,备份完全备份之后变化了的数据文件、日志文件以及数据库中其他被修改的内容。差异备份耗费的时间比完全备份少,但也会占用一些时间,同完全备份一样,差异备份过程中也运行用户访问数据库并对数据进行操作,并且在差异备份过程中会把这些操作也一起备份起来。

(3)事务日志备份
是备份从上次备份之后的日志记录,而在默认情况下,事务日志备份完成后要截断日志,事务日志备份记录了用户对数据进行的修改操作。随着时间的推移,日志中的记录数会越来越多,容量有时比数据库备份大,这样会占满整个磁盘空间。因此,为了避免这种情况的发生,必须定期地将日志记录中不必要的记录清除掉,以节省空间。清除掉无用日志记录的过程叫做截断日志。

(4)增量备份
是针对于上一次备份的,备份上一次备份后所有发生变化的文件。在增量备份过程中,只备份有标记的选中的文件和文件夹,它清除标记,即备份后标记文件

与数据备份相对应的就是数据恢复,数据恢复是指将数据恢复到事故之前的状态,可以将其看成是数据备份操作的逆过程。数据备份是数据恢复的前提,数据恢复是数据备份的目的,无法恢复的数据备份是没有任何意义的。

什么是游标

在数据库中,游标提供了一种对从表中检索出的数据进行操作的灵活手段。它实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。

游标总是与一条SQL选择语句相关联,因为游标由结果集(可以是零条、一条或由相关的选择语句检索出的多条记录)和结果集中指向特定记录的游标位置组成。当决定对结果集进行处理时,必须声明一个指向该结果集的游标。

游标允许应用程序对查询语句select返回的行结果集中每一行进行相同或不同的操作,而不是一次对整个结果集进行同一种操作。它还提供对基于游标位置而对表中数据进行删除或更新的能力。而且,正是游标把作为面向集合的数据库管理系统和面向行的程序设计两者联系起来,使两个数据处理方式能够进行沟通

如果数据库日志满了,会出现什么情况

日志文件(Log File)记录所有对数据库数据的修改,主要是保护数据库以防止故障,以及恢复数据时使用,特点如下:

(1)每个数据库至少包含两个日志文件组。每个日志文件组至少包含两个日志文件成员
(2)日志文件组以循环方式进行写操作
(3)每一个日志文件成员对应一个物理文件。

通过日志文件来记录数据库事务可以最大限度地保证数据的一致性与安全性,但一旦数据库中日志满了,就只能执行查询等读操作,不能执行更改备份等操作。其原因是任何写操作都要记录日志,也就是说基本上处于不能使用状态。

如何判断谁往数据库中插入了一行数据

通过下面3中方法来达到这个目的:事先打开审计功能、表上建立触发器或者查看logmnr等。

(1)审计功能
先设置audit_trail参数,决定审计结果的保存地点,然后执行audit insert on schema. table_name whenever successful;当有执行insert操作的动作后,根据audit_trail 参数到相应位置去看审计结果即可。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。