2.当sql 发一起的update 语句时,oracle会对这一行上两把锁,一把是共享锁,一把是行锁。顺序是先上共享锁,再上行锁(其实是一个标志位)。当Commit时,把行锁的标记改为未锁,然后oracle会copy一份数据到undo表空间,提交完成后,undo表空间里的数据不变。多次的commit都在undo表空间里保留一份数据,为闪回做好准备。
3.oracle内部为每条sql语句都会有一份执行计划,这些执行计划都是会参考一些系统的参数,比如表的行数,字段数等作为参考。
在EM里,我们可以查看到那些性能不好的SQL,oracle也会提供一些优化的方案。
在写SQL时,尽量避免用OR 、!= 、NOT IN,这些都会产生全表扫描,影响效率。
如果一定要动态生成SQL,最好用多态的方式来装载不同的SQL
更多信息请看 http://blog.sina.com.cn/vwaen
待续。。。