数据库驱动程序中已编译的预备语句是否仍需要在数据库中进行编译?

2024-01-07

在 Oracle JDBC 驱动程序中,有一个选项可以缓存准备好的语句。我对此的理解是,准备好的语句由驱动程序预编译,然后缓存,这提高了缓存的准备好的语句的性能。

我的问题是,这是否意味着数据库永远不必编译那些准备好的语句? JDBC 驱动程序是否发送一些预编译的表示形式,或者数据库本身是否仍然发生某种解析/编译?


当您使用隐式语句缓存(或显式语句缓存的 Oracle 扩展)时,Oracle 驱动程序将在 close() 之后缓存准备好的或可调用的语句,以便与物理连接重用。

所以会发生的情况是:如果使用了准备好的语句,并且物理连接从未见过它,它会将 SQL 发送到数据库。根据数据库之前是否见过该语句,它将执行硬解析或软解析。因此,通常如果您有 10 个连接池,您将看到 10 次解析,其中之一是硬解析。

在连接上关闭语句后,Oracle 驱动程序会将已解析语句(共享游标)的句柄放入 LRU 缓存中。下次您在该连接上使用prepareStatement 时,它会找到要使用的缓存句柄,并且根本不需要发送SQL。这会导致执行时没有 PARSE。

如果物理连接上使用的(不同的)准备语句多于缓存的大小,则关闭最长的未使用的打开共享游标。这会导致下次再次使用该语句时再次进行软解析 - 因为 SQL 需要再次发送到服务器。

这基本上与一些中间件数据源更通用地实现的功能相同(例如 JBoss 中的准备语句缓存)。仅使用两者之一以避免双重缓存。

您可以在这里找到详细信息:

http://docs.oracle.com/cd/E11882_01/java.112/e16548/stmtcach.htm#g1079466 http://docs.oracle.com/cd/E11882_01/java.112/e16548/stmtcach.htm#g1079466

另请查看支持此功能并与 FAN 交互的 Oracle 统一连接池 (UCP)。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

数据库驱动程序中已编译的预备语句是否仍需要在数据库中进行编译? 的相关文章

随机推荐