SQL语句的执行过程

Linux大全评论1.5K views阅读模式

服务器接收到SQL语句之后,要经过如下步骤完成操作:Parse(解析)—> Bind(绑定)—> Execute(执行)。

画个流程图比较明显的表示了这些过程:

SQL语句的执行过程

下面说明执行的具体细节:

1 Select(查询)

SQL语句的执行过程

2 INSERT/DELETE/UPDATE

这些都是对数据进行修改的语句,画个流程图,简洁明了:

SQL语句的执行过程

这个叙述比较混乱,举个例子:

有这样一行,学生id是100,成绩是99,现在要将这个成绩改成80(这个ID对应的行,有且仅有一行)。

SQL应该是update student set score=80 where stu_id = 100;

假设这个数据块已经在buffer cache里了,那么就要首先取得两个锁:表的数据行独占锁和数据行独占锁。下面,就要把记录为99的数据Redo Entry复制到log buffer。然后,会产生undo block,大概是这样的(100,99)。这之后,会把修改的Redo Entry也复制到log buffer里去,这个是80的。所有这些做完以后,成绩会被从99更新到80。

这一切之后,输入commit。

这时数据库会做这些事情:

1 会把commit的Redo Entry复制到Log Buffer里,这样的话,按照时间顺序,Log Buffer里就有了如下三组:(100,99),(100,80),commit。

2 启动LGWR。按照上面的顺序把Log Buffer写到Online Logfile里。

企鹅博客
  • 本文由 发表于 2019年8月4日 06:04:06
  • 转载请务必保留本文链接:https://www.qieseo.com/183684.html

发表评论