数据库原理与应用(SQL Server)笔记——第十五章 事务与数据库管理

本文主要是介绍数据库原理与应用(SQL Server)笔记——第十五章 事务与数据库管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 一、事务
  • 二、锁定机制
    • (一)不一致性
    • (二)锁模式
    • (三)死锁
  • 三、数据库管理
    • (一)SQL Server身份验证
    • (二)数据库的备份
    • (三)数据库的恢复

一、事务

数据库中的事务是单个逻辑单元执行的一系列操作,事务的处理必须满足ACID原则,有以下四种:
(一)原子性
使数据库管理系统中满足原子性的子系统是事务管理子系统,原子性意味着若事务中的某个操作失败,整个事务都会回滚到初始状态,即事务包括的操作要么全执行,要么全不执行。
(二)一致性
一致性是指事务必须使数据库从一个一致性状态变换到另一个一致性状态,即一个事务执行之前和执行之后,数据库都必须处于一致性状态。
(三)隔离性
一个事务的执行不被其他事务干扰,即为事务的隔离性。
(四)持续性
数据库管理系统的恢复管理子系统保证了事务的持续性,持续性是指事务一旦提交,则对数据库中的数据的改变是永久性的。

之所以叫事务的ACID属性,是因为包括原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)以及持续性(Durability),所以,简称事务的ACID。

二、锁定机制

(一)不一致性

锁定机制用来解决多个数据库用户同时对同一个数据块访问所引起并发操作的情况,若不对其进行相关的控制,会导致数据库中的数据的不一致性,包括丢失更新、脏读、不可重复读、幻读等问题。

(二)锁模式

SQL Server使用了不同的锁模式来锁定资源,锁模式确定了并发事务访问资源的方式,有共享锁、更新锁、排他锁、意向锁、架构锁、大容量更新锁、键范围锁七种。每种锁都有不同的特点,例如,共享锁(S锁)允许事务访问资源,不允许修改;更新锁(U锁)可以防止死锁;排他锁(X锁)可以防止并发事务访问和修改……

例如,事务R获得了数据对象S上的排他锁,则R对S能读、写,但其他事务对S不能读、写。

(三)死锁

当两个事务分别锁定某个资源,而又等待对方释放其锁定的资源时,将发生死锁。另外,SQL Server的死锁监视器会监视事务,同时会根据死锁优先级来决定回滚,若死锁优先级相同,则会将回滚开销较低的选为死锁牺牲品。

三、数据库管理

(一)SQL Server身份验证

SQL Server的身份验证模式包括Windows 身份验证模式和混合验证模式,当采用后者时,允许使用Windows 账号登陆,也允许使用SQL Server账号登陆。

(二)数据库的备份

数据库备份是确保数据库中的数据安全性和完整性的重要手段,常用的备份方式有以下:
1、完整备份:
完整备份整个数据库。优点是恢复性强,提供了完整性的数据库副本;缺点是完整的备份文件占存储空间和备份时间长。
2、增量备份:
备份上一次备份以来的更新数据,该方式可以节省备份时间和存储空间。
3、事务日志备份
只备份事务日志文件,文件中记录了数据库的改变情况,该方式用时最节省时间。

总的来说,要根据实际情况来选择备份方式,且通常还是要综合使用多种备份类型来共同保障数据库,以提供最佳的数据保护和恢复能力。

(三)数据库的恢复

数据库恢复的基础是利用转储的冗余数据,即通过数据转储的数据库后备副本和日志文件来进行恢复。其中,数据转储是指数据库管理员定期将整个数据库复制到另一个硬盘保存起来,保存的数据即为数据库后备副本。

冗余数据是指可以由基本数据导出的数据,这些数据在数据库中重复存储,虽然冗余数据容易破坏数据库的完整性并给数据库的维护带来困难,但可以通过冗余数据来重建被破坏或不正确的数据,从而作为恢复数据的手段。

在SQL Server中有三种恢复模式,分别是简单恢复、完整恢复和大容量日志恢复模式。

这篇关于数据库原理与应用(SQL Server)笔记——第十五章 事务与数据库管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/863716

相关文章

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

AssetBundle学习笔记

AssetBundle是unity自定义的资源格式,通过调用引擎的资源打包接口对资源进行打包成.assetbundle格式的资源包。本文介绍了AssetBundle的生成,使用,加载,卸载以及Unity资源更新的一个基本步骤。 目录 1.定义: 2.AssetBundle的生成: 1)设置AssetBundle包的属性——通过编辑器界面 补充:分组策略 2)调用引擎接口API

用Microsoft.Extensions.Hosting 管理WPF项目.

首先引入必要的包: <ItemGroup><PackageReference Include="CommunityToolkit.Mvvm" Version="8.2.2" /><PackageReference Include="Microsoft.Extensions.Hosting" Version="8.0.0" /><PackageReference Include="Serilog

mysql索引四(组合索引)

单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引;组合索引,即一个索引包含多个列。 因为有事,下面内容全部转自:https://www.cnblogs.com/farmer-cabbage/p/5793589.html 为了形象地对比单列索引和组合索引,为表添加多个字段:    CREATE TABLE mytable( ID INT NOT NULL, use

mysql索引三(全文索引)

前面分别介绍了mysql索引一(普通索引)、mysql索引二(唯一索引)。 本文学习mysql全文索引。 全文索引(也称全文检索)是目前搜索引擎使用的一种关键技术。它能够利用【分词技术】等多种算法智能分析出文本文字中关键词的频率和重要性,然后按照一定的算法规则智能地筛选出我们想要的搜索结果。 在MySql中,创建全文索引相对比较简单。例如:我们有一个文章表(article),其中有主键ID(

mysql索引二(唯一索引)

前文中介绍了MySQL中普通索引用法,和没有索引的区别。mysql索引一(普通索引) 下面学习一下唯一索引。 创建唯一索引的目的不是为了提高访问速度,而只是为了避免数据出现重复。唯一索引可以有多个但索引列的值必须唯一,索引列的值允许有空值。如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该使用关键字UNIQUE,把它定义为一个唯一索引。 添加数据库唯一索引的几种

mysql索引一(普通索引)

mysql的索引分为两大类,聚簇索引、非聚簇索引。聚簇索引是按照数据存放的物理位置为顺序的,而非聚簇索引则不同。聚簇索引能够提高多行检索的速度、非聚簇索引则对单行检索的速度很快。         在这两大类的索引类型下,还可以降索引分为4个小类型:         1,普通索引:最基本的索引,没有任何限制,是我们经常使用到的索引。         2,唯一索引:与普通索引

《offer来了》第二章学习笔记

1.集合 Java四种集合:List、Queue、Set和Map 1.1.List:可重复 有序的Collection ArrayList: 基于数组实现,增删慢,查询快,线程不安全 Vector: 基于数组实现,增删慢,查询快,线程安全 LinkedList: 基于双向链实现,增删快,查询慢,线程不安全 1.2.Queue:队列 ArrayBlockingQueue:

关于如何更好管理好数据库的一点思考

本文尝试从数据库设计理论、ER图简介、性能优化、避免过度设计及权限管理方面进行思考阐述。 一、数据库范式 以下通过详细的示例说明数据库范式的概念,将逐步规范化一个例子,逐级说明每个范式的要求和变换过程。 示例:学生课程登记系统 初始表格如下: 学生ID学生姓名课程ID课程名称教师教师办公室1张三101数学王老师101室2李四102英语李老师102室3王五101数学王老师101室4赵六103物理陈

数据库期末复习知识点

A卷 1. 选择题(30') 2. 判断范式(10') 判断到第三范式 3. 程序填空(20') 4. 分析填空(15') 5. 写SQL(25') 5'一题 恶性 B卷 1. 单选(30') 2. 填空 (20') 3. 程序填空(20') 4. 写SQL(30') 知识点 第一章 数据库管理系统(DBMS)  主要功能 数据定义功能 (DDL, 数据定义语