astingracle执行sql语句过程
1.parse(解析)
  软解析/硬解析(第一次执行sql需要进行硬解析)
  1)从共享池的库缓冲区搜索,确定该语句是否曾经执行过,凡是执行过的sql语句,oracle会使用hash函数进行计算,产生一个很小的文本记录。如果是第一次执行,则进入第二步;
  2)检查语法、权限等等(权限的信息是存放在oracle的数据字典中),oracle先从共享池的数据字典缓冲区中搜索,如果没有找到,再从数据文件(system表空间的数据文件)中读取,然后存放在共享池的数据字典缓冲区中,以便共享;
  3)分析过程中,对访问到的表进行锁操作,目的是为了保护表的结构不被修改;
  4)oracle优化器会根据数据的存储结构(表的存储结构、索引)统计信息等。计算各种读取的代价,选择一条最佳路径(代价最低),生成执行计划,同时编译并存储在共享池的库缓冲区中,以便共享。
2.bind(绑定变量)
3.execute(执行)
  先从数据缓冲区查找数据,如果没有,再从数据文件中读取数据到数据缓冲区、保持,以便共享。
4.fetch
  把结果返回给用户。
 
			posted @ 
2012-09-27 21:39 kxbin 阅读(692) | 
评论 (1) | 
编辑 收藏posted @ 
2012-07-19 09:36 kxbin 阅读(1438) | 
评论 (2) | 
编辑 收藏
			    只有注册用户登录后才能阅读该文。
阅读全文
			posted @ 
2011-12-22 21:09 kxbin 阅读(205) | 
评论 (1) | 
编辑 收藏
			    拥有好身体,拥有好的未来!
    从现在开始善待自己的身体,让自己拥有健壮的身体!
			
posted @ 
2011-11-28 10:36 kxbin 阅读(581) | 
评论 (0) | 
编辑 收藏