数据库原理与应用(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

相关文章

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语