【问题标题】:MySql JDBC call to stored procedure return too many rowsMySql JDBC 调用存储过程返回太多行
【发布时间】:2012-04-10 18:01:07
【问题描述】:

这是 MySQL 中的存储过程:

CREATE PROCEDURE topModels(modelCount INT)
BEGIN
  select brand_name as brandName, 
     model_number as modelNumber, 
     model_description as modelDescription,
     parts 
  from 
  (
     select model_number, model_description, parts  
        ,@rownum := if(@brand=t.brand_name, @rownum, 0) + 1 as rownum
        ,@brand := t.brand_name as brand_name
     from
     (
         select brand_name, model_number, model_description, parts, 
         from model f
         group by brand_name, model_number, model_description
         order by brand_name, sum(sold_count) desc
     ) t
 ) tbl 
 where rownum<=5
END

当我打开 MySQL 工作台并执行以下操作时:

 CALL topModels(5)

它返回大约 3000 行,这是正确的结果。

当我从 Java 运行它时:

  java.sql.CallableStatement cs  = connection.
      prepareCall("CALL topModels(5)");
  java.sql.ResultSet rs = cs.executeQuery();

它返回大约 400,000 行,就好像它忽略了“where rownum

我做错了什么?

【问题讨论】:

  • MySQL 工作台通常会限制结果集的大小。
  • 我知道这一点,但这不是问题所在。它告诉我它返回 3xxx 行,这正是我在整个查询上运行 count(*) 时的行数

标签: java mysql stored-procedures


【解决方案1】:

我看到你的程序有modelCount,但你从不使用它。

IIRC MySQL 没有rownum。请改用LIMIT

String sql = "SELECT * FROM tbl ... LIMIT " + modelCount.

很遗憾,您不能在LIMIT 中使用过程参数(至少在 5.1 之前不能)。

【讨论】:

    【解决方案2】:

    您可能需要使用 JDBC 调用语法,例如:

    conn.prepareCall("{call topModels(5)}");

    【讨论】:

    • 如果您不确定,这应该是评论而不是答案。
    【解决方案3】:

    我对 Java JDBC 完全陌生(来自 .NET 阵营)。但是查看 Oracle 文档。我认为您需要分别传入参数:

     java.sql.CallableStatement cs  = connection.prepareCall("CALL topModels(?)");
     cs.setInt(1, 5); // <--  I'm assuming you need set the parameter like this
     java.sql.ResultSet rs = cs.executeQuery();
    

    【讨论】:

      【解决方案4】:

      看看这个框架 (https://code.google.com/p/lindbergframework/)。轻松处理存储过程和函数,包括自动处理游标。

      https://code.google.com/p/lindbergframework/

      【讨论】:

        猜你喜欢
        • 2011-12-29
        • 1970-01-01
        • 2020-01-21
        • 2016-05-03
        • 1970-01-01
        • 2012-02-08
        • 2015-03-16
        • 2011-01-09
        • 2018-08-13
        相关资源
        最近更新 更多