数据库(六)——数据库控制功能

一、事务管理

1.事务

一组数据库操作,要么全部成功,要么全部失败(原子性)。

示例:银行转账

sql 复制代码
BEGIN TRANSACTION;
UPDATE 账户 SET 余额 = 余额 - 100 WHERE 账号 = 'A'; -- 扣钱
UPDATE 账户 SET 余额 = 余额 + 100 WHERE 账号 = 'B'; -- 加钱
COMMIT; -- 提交
-- 如果第二步出错,执行 ROLLBACK,A的钱不会扣

2.事务的四大特性(ACID)

3.事务的状态转化

sql 复制代码
开始 → 部分提交 → 提交  
    ↘     
      失败 → 终止 → 回滚
  • 活动:正在执行

  • 部分提交:最后一条语句执行完

  • 失败:发现无法继续(如除零、约束冲突)

  • 终止:回滚前的状态

  • 提交:修改真正写入磁盘

二、故障恢复技术

1.故障类型

2.恢复的核心技术

日志文件(Write-Ahead Logging, WAL)

先写日志,后写数据库(必须保证日志先落盘)

检查点(Checkpoint)

定期执行

  1. 将内存中的脏缓冲区刷到磁盘

  2. 写一条日志 <CHECKPOINT>,记录当前所有活跃事务

好处:恢复时不需要从头扫描整个日志,从最近检查点开始即可。

数据备份

  • 完全备份:整个数据库复制一份

  • 增量备份:只备份上次备份后改变的数据

  • 差异备份:只备份上次完全备份后改变的数据

三、并发控制技术

1.并发带来的问题

2.基于锁的并发控制

锁的类型

  • X 锁(写锁 / 排他锁):加了 X 锁后,别人既不能读也不能写,只能等锁释放。
  • S 锁(读锁 / 共享锁):加了 S 锁后,别人可以加 S 锁一起读,但不能加 X 锁写。

封锁协议

相关推荐
一只鹿鹿鹿几秒前
信息化项目管理规范(参考Word文件)
java·大数据·运维·开发语言·数据库
这个DBA有点耶2 分钟前
多模融合数据库深度解析:关系、文档、向量、图如何统一?
数据库·自然语言处理·aigc·dba·改行学it
anew___20 分钟前
《数据库原理》精要解读(三)—— SQL:与数据库对话的艺术
数据库·sql·oracle
KaiwuDB20 分钟前
KWDB 3.2.0 版本发布,数据管理查询增强,安装部署体验全面升级
数据库
暴躁小师兄数据学院27 分钟前
【AI大数据工程师特训笔记】第10讲:数据库用户、权限管理、数据库约束
大数据·数据库·笔记·sql·postgresql
凤山老林38 分钟前
DDD(领域驱动设计)在复杂业务系统中的落地指南
java·开发语言·数据库·ddd·领域驱动
凯瑟琳.奥古斯特1 小时前
子查询原理与实战案例解析
开发语言·数据库·职场和发展·数据库开发
KaMeidebaby1 小时前
卡梅德生物技术快报|酵母双杂交 cDNA 文库构建与蛋白互作筛选流程
服务器·前端·数据库·人工智能·算法
暴躁小师兄数据学院1 小时前
【AI大数据工程师特训笔记】第02讲:PostgreSQL数据库生态全景
大数据·数据库·人工智能·postgresql
沐风___1 小时前
App 上架之后:如何看数据、获取用户与持续迭代产品
服务器·前端·数据库