0

我在下面native sql query。我正在使用Oracle数据库。

select
         * 
     from
         (select
             row_.*,
             rownum rownumber 
         from
             (select
                 colmn1,
                 colmn2,
                 colmn3,
                 colmn4,
                 colmn5,
                 colmn6,
                 from
                 Table5
             where
                 colmn5 In (
                    '19901','10001'
                 ) 
             order by
                colmn1 ) row_ ) 
         Where
             Rownumber <= 50000
             and rownumber > 0

上面的查询返回50000记录。如果我执行上面的查询sqldeveloper,它只需要30 seconds但在 spring 和 hibernate 集成应用程序中需要15 minutes。我怎样才能提高性能?

谢谢!

4

1 回答 1

0

你有两个内部选择。内部选择总是可能导致性能不佳,因为它可能会阻碍数据库找到最佳搜索策略。

据我所知,您仅使用内部选择来处理行号。如果您只使用最内部的选择并在 java/hibernate 级别处理行号,那么您将获得更好的性能。

你只使用这个选择

select colmn1, colmn2, colmn3, colmn4, colmn5, colmn6,
   from Table5
   where colmn5 In ('19901','10001') 
   order by colmn1

其中,由于它没有任何数据库特性,因此可以更容易地被 HQL 语句替换,从而使您的程序独立于使用的数据库(Java 类和属性名称应替换为真实名称):

from Table5_Class
   where colmn5_Prop in ('19901','10001') 
   order by colmn1_prop

然后你用Where Rownumber <= 50000 and rownumber > 0hibernate方法替换你的where条件Query.setMaxResults(50000)并且Query.setFirstResult(0)(备注:setFirstResult(0)是多余的,因为第0行总是第一个,但我想你也想获得接下来的50000行,然后你可以使用setFirstResult(n ))。

如果您需要将行号作为参数,那么您可以为此使用结果列表的索引。

P.S:我无法告诉您为什么您的选择在 SQL 开发人员中比在 Hibernate 中快得多。

于 2012-10-18T06:29:58.300 回答