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

一、事务管理

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 锁写。

封锁协议

相关推荐
倔强的石头_16 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神2 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据2 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_2 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡2 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧3 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon3 天前
SQL学习指南——视图
数据库·sql
活宝小娜3 天前
mysql详细安装教程
数据库·mysql·adb