数据库原理与应用(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编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

Spring事务中@Transactional注解不生效的原因分析与解决

《Spring事务中@Transactional注解不生效的原因分析与解决》在Spring框架中,@Transactional注解是管理数据库事务的核心方式,本文将深入分析事务自调用的底层原理,解释为... 目录1. 引言2. 事务自调用问题重现2.1 示例代码2.2 问题现象3. 为什么事务自调用会失效3