image

编辑人: 青衫烟雨

calendar2025-06-14

message3

visits1008

OracleSQL共享的原理是什么?什么样的SQL会被共享?

为了不重复解析相同的SQL语句,在第一次解析之后,
Oracle将SQL语句存放在内存中。这块位于系统全局区域
SGA(systemglobal area)的共享池(shared buffer pool中的
内存可以被所有的数据库用户共享。因此,当你执行一个SQL
语句(有时被称为一个游标)时,如果它和之前执行过的语句完全
相同,Oracle就能很快获得已经被解析的语句以及最好的执行
方案。Oracle的这个功能大大地提高了SQL的执行性能并节省
了内存的使用。
可惜的是,Oracle只对简单的表提供高速缓冲
(cache bufferiIlg),这个功能并不适用于多表连接查询。数据
库管理员必须在启动参数文件中为这个区域设置合适的参数,
当这个内存区域越大,就可以保留更多的语句,当然被共享的
可能性也就越大了。当向Oracle提交一个SQL语句时,Oracle
会首先在这块内存中查找相同的语句

SQL共享的三个条件:

当前被执行的语句和共享池中的语句必须完全相同 (包括大小写、空格、换行等)

两个语句所指的对象必须完全相同 (同义词与表是不同的对象)

两个SQL语句中必须使用相同的名字的绑定变量(bind variables)

喵呜刷题:让学习像火箭一样快速,快来微信扫码,体验免费刷题服务,开启你的学习加速器!

创作类型:
原创

本文链接:OracleSQL共享的原理是什么?什么样的SQL会被共享?

版权声明:本站点所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明文章出处。
分享文章
share