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

一、事务管理

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

封锁协议

相关推荐
瀚高PG实验室1 小时前
postgresql因在从库备份时间长而失败
运维·数据库·postgresql·瀚高数据库
phltxy1 小时前
Redis:从入门到精通的第一步
数据库·redis·缓存
User_芊芊君子1 小时前
数据库V9R4C19安全加固:最小权限部署与不可逆哈希存储实战
数据库·安全·哈希算法
消失的旧时光-19433 小时前
SQL 第五篇:SQL 如何真正接入 Spring Boot 项目(企业 Mapper 分层实战)
数据库·spring boot·sql
dfdfadffa10 小时前
如何用模块化方案组织一个可扩展的前端组件库项目
jvm·数据库·python
2301_8125396710 小时前
SQL中如何高效实现分组数据的批量更新_利用窗口函数与JOIN
jvm·数据库·python
2501_9012005310 小时前
如何实现SQL存储过程存储过程参数标准化_统一命名规范
jvm·数据库·python
运气好好的10 小时前
Golang怎么用embed嵌入SQL文件_Golang如何将SQL迁移文件嵌入Go程序统一管理【技巧】
jvm·数据库·python
念何架构之路11 小时前
MySql常见ORM
数据库·mysql