博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL语句的执行过程
阅读量:5890 次
发布时间:2019-06-19

本文共 782 字,大约阅读时间需要 2 分钟。

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

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

   

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

    1 Select(查询)

   

2 INSERT/DELETE/UPDATE

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

 

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

    有这样一行,学生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里。

     3 告诉用户进程,结束了。

     很长时间以来,我都以为commit以后,数据会被写到数据文件里,就是Datafile,但是事实不是这样。上面的步骤完成之后Datafile里存在的还是(100,99)。下次再查询的时候,就直接查缓冲区数据了。如果缓冲区紧张了,DBWR会开始工作,将缓冲刷进数据文件。

转载地址:http://wyfsx.baihongyu.com/

你可能感兴趣的文章
Linux下的搜索查找命令的详解(locate)
查看>>
安装gulp及相关插件
查看>>
如何在Linux用chmod来修改所有子目录中的文件属性?
查看>>
Hyper-V 2016 系列教程30 机房温度远程监控方案
查看>>
笔记:认识.NET平台
查看>>
cocos2d中CCAnimation的使用(cocos2d 1.0以上版本)
查看>>
【吉光片羽】短信验证
查看>>
gitlab 完整部署实例
查看>>
GNS关于IPS&ASA&PIX&Junos的配置
查看>>
影响企业信息化成败的几点因素
查看>>
SCCM 2016 配置管理系列(Part8)
查看>>
struts中的xwork源码下载地址
查看>>
ABP理论学习之仓储
查看>>
我的友情链接
查看>>
CentOS图形界面和命令行切换
查看>>
HTML5通信机制与html5地理信息定位(gps)
查看>>
加快ALTER TABLE 操作速度
查看>>
PHP 程序员的技术成长规划
查看>>
python基础教程_学习笔记19:标准库:一些最爱——集合、堆和双端队列
查看>>
js replace,正则截取字符串内容
查看>>