服务器接收到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会开始工作,将缓冲刷进数据文件。Oracle控制文件的一点研究Oracle 10g 在RedHat Linux 5.3 系统安装图解全过程(单机)相关资讯 SQL
- SQL 新手指南 (09/10/2015 10:57:53)
- SQL导入txt以及SQL中的时间格式操 (01/25/2015 11:35:04)
- SQL 事务及实例演示 (08/12/2014 10:36:37)
| - SQL 中的正则函数 (06/28/2015 15:59:48)
- SQL 集合(笔记) (01/15/2015 20:19:06)
- Oracle shell调用SQL操作DB (02/03/2014 10:48:18)
|
本文评论 查看全部评论 (1)
评论声明- 尊重网上道德,遵守中华人民共和国的各项有关法律法规
- 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
- 本站管理人员有权保留或删除其管辖留言中的任意内容
- 本站有权在网站内转载或引用您的评论
- 参与本评论即表明您已经阅读并接受上述条款
|
|