【体系结构】一条SQL语句经历了什么
我们都知道Oracle是通过SQL语句来查询或者进行修改的。那么SQL从客户端执行开始,经历了哪些进程?哪些SGA?是怎么进入到数据文件的呢?请往下看
情况一:在数据库中查询select如图所示:
① 客户端输入SQL,SQL语句通过网络到达数据库实例,前台进程(服务器进程)接受SQL语句,PGA这时会分配一段空间给前台进程。
② 将SQL语句解析为“执行计划”,然后才能执行
解析这部分消耗很多资源:CPU和I/O。
此时SQL语句和执行计划都会被缓存在共享池(shared pool)中
③ 通过生成的执行计划在数据库缓冲区(buffer cache)和dbf文件中找数据
此过程会涉及数据库缓冲区,数据库缓冲区的作用就是缓存dbf的数据。所以是首先从数据库缓冲区看是否有数据,有的话就从数据库缓冲区中获取,如果没有就从dbf文件中获取。dbf中的数据首先会传到数据库缓冲区中。然后在通过前台进程将数据返回客户端。
① ② ③过程都是有前台进程完成
①同查询一样,客户端将要求前台进程传输到共享池中,然后到数据库缓冲区读数据。如果数据库缓冲区中没有数据,那么就从dbf文件中找,dbf中的数据会传送到数据库缓冲区,由前台进程进行读取。
②前台进程在数据库缓冲区中对表进行修改,提交,此时,会产生日志。产生的日志会写到日志缓冲区中。
③在数据库缓冲区中修改完数据后,此时内存中的数据和数据文件中的数据不一致。需要将内存中的数据写到数据文件中。这个过程由数据库写进程来完成。
④内存中日志缓冲区产生的日志需要写到日志文件中,这个过程由日志写进程完成。
------------- end ---------------
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。