0

3 つの IN パラメーターと 6 つの OUT パラメーターを使用して MySql ストアド プロシージャを呼び出さなければならないという要件があります。

手順

DELIMITER $$ 
DROP PROCEDURE IF EXISTS GET_PRODUCT_INFO $$

CREATE PROCEDURE GET_PRODUCT_INFO(IN productName varchar(25),
  IN divisionID int(11), IN productQuantity int(11),
  OUT Price double, OUT price_without_vat double,
  OUT vat double, OUT Quantity int, OUT ProductsId int, OUT ExpDate date)

BEGIN

   select I.quantity into Quantity from ProductInventory I
     where I.pname=productName and I.divid=divisionID ;

   if Quantity > productQuantity THEN
      select P.productID,P.price,P.price_without_vat,P.vat, I.quantity,P.ExpiryDate 
        into ProductsId,Price,price_without_vat,vat,Quantity,ExpDate 
        from product P,ProductInventory I
        where P.pname=productName and I.pname=productName 
          and P.orgid=divisionID and I.divid=divisionID ;

      update productinventory 
        set quantity=(quantity-productQuantity)
        where pname=productName and divID=divisionID;
   END IF;
END $$

call GET_PRODUCT_INFO('Crocin',1,2,@Price,@price_without_vat,@vat,@Quantity,@ProductsId,@ExpiryDate)$$

ここで、mysql cmd プロンプトでレコードを取得できます...しかし、JDBC コードからプロシージャを呼び出そうとすると、このエラーが発生します

例外

java.sql.SQLException: com.mysql.jdbc.CallableStatement.checkParameterIndexBounds(CallableStatement.java:1002) で 9 のパラメーター インデックスが範囲外 (1, 8) である:971)

callableStatement = (CallableStatement)con.prepareCall("{call GET_PRODUCT_INFO(?,?,?,?,?,?,?,?,?)}");
callableStatement.setInt(2, 1);
callableStatement.setInt(3, quantity);
callableStatement.registerOutParameter(4, Types.DOUBLE);
callableStatement.registerOutParameter(5, Types.DOUBLE);
callableStatement.registerOutParameter(6, Types.DOUBLE);
callableStatement.registerOutParameter(7, Types.INTEGER);
callableStatement.registerOutParameter(8, Types.INTEGER);
callableStatement.registerOutParameter(9, Types.DATE);--->Exception here
4

1 に答える 1

1

callableStatement.setString(1, "SomeText");

これも含めてください。1パラメータを見逃しました。

于 2013-03-06T08:14:30.017 に答える