« 《Oracle DBA手记》第二部启动募集中 | Blog首页 | 2010 数据库技术大会 即将揭幕 »
Java的DatabaseMetaData getPrimaryKeys调用
作者:eygle | 【转载请注出处】|【云和恩墨 领先的zData数据库一体机 | zCloud PaaS云管平台 | SQM SQL审核平台 | ZDBM 数据库备份一体机】
链接:https://www.eygle.com/archives/2010/03/databasemetadata_getprimarykeys.html
最近,我们在客户的数据库中发现了如下一个Top SQL,其逻辑读占据第一位:链接:https://www.eygle.com/archives/2010/03/databasemetadata_getprimarykeys.html
CPU Elapsd
Buffer Gets Executions Gets per Exec %Total Time (s) Time (s) Hash Value
--------------- ------------ -------------- ------ -------- --------- ----------
1,870,588,542 104,176 17,956.0 29.1 ######## 12116.51 958390712
Module: JDBC Thin Client
SELECT NULL AS table_cat, c.owner AS table_schem,
c.table_name, c.column_name, c.position AS key_seq
, c.constraint_name AS pk_name FROM all_cons_columns c, a
ll_constraints k WHERE k.constraint_type = 'P' AND k.table_nam
e = :1 AND k.owner like :2 escape '/' AND k.constraint_name
= c.constraint_name AND k.table_name = c.table_name AND k.
owner = c.owner ORDER BY column_name
格式化一下,这个SQL的作用是什么呢?
SELECT NULL AS table_cat, c.owner AS table_schem, c.table_name,
c.column_name, c.POSITION AS key_seq, c.constraint_name AS pk_name
FROM all_cons_columns c, all_constraints k
WHERE k.constraint_type = 'P'
AND k.table_name = :1
AND k.owner LIKE :2 ESCAPE '/'
AND k.constraint_name = c.constraint_name
AND k.table_name = c.table_name
AND k.owner = c.owner
ORDER BY column_name
通过 Google 找到了这样一个答案:
当JAVA程序中通过DatabaseMetaData#getPrimaryKeys()调用,将会执行这个SQL,如果不及时关闭,则还可能产生严重的内存占用。
那么怎样规避这个调用,考察这个调用是否必要显得非常重要,这个SQL导致的逻辑度太过显著。
对Top SQL保持敏感是DBA的重要守则。
记录以备忘。
-The End-
历史上的今天...
>> 2018-03-26文章:
>> 2012-03-26文章:
>> 2007-03-26文章:
>> 2006-03-26文章:
By eygle on 2010-03-26 21:06 | Comments (2) | Case | 2521 |
数据库/ 文件。 一定要 关闭......
我也碰到这个问题,是hibernate产生的。hibernate这个版本默认打开了这个功能。