2

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();

「whererownum<=5」条件を無視するかのように約400,000行を返します。

私は何を間違えますか?

4

4 に答える 4

1

私はあなたの手順が持っているように見えますがmodelCount、あなたはそれを決して使用しません。

IIRCMySQLにはがありませんrownumLIMIT代わりに使用してください:

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

残念ながら、でプロシージャパラメータを使用することはできませんLIMIT(少なくとも5.1まで)。

于 2012-07-08T21:48:59.107 に答える
0

このフレームワーク ( https://code.google.com/p/lindbergframework/ ) を見てください。カーソルの自動処理を含む、ストアド プロシージャと関数の簡単な処理。

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

于 2013-07-04T14:28:37.547 に答える
0

私は 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();
于 2012-07-08T21:40:59.017 に答える
0

次のような JDBC 呼び出し構文を使用する必要がある場合があります。

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

于 2012-04-10T20:09:27.790 に答える