0

Spring+ MSSQL Server 2008 アプリケーションを実装しています。SimpleJDBCCall API を使用してストアド プロシージャを実行し、結果を取得します。

単一テーブルの結果を持つストアド プロシージャの場合は正常に動作しますが、複数のテーブルの結果を持つプロシージャに使用する方法がわかりません。これは、2 つの結果テーブルを返すデータベースのクエリのスクリーンショットです。1

これが私が使用するコードです。このコードは単一のテーブル結果で適切に機能します`

public class LoadOnDemandSP extends StoredProcedure{
    private static final String SPROC_NAME = "sps_IME_EF_GetAllMarketData";

    public LoadOnDemandSP(DataSource ds) {
        super(ds, SPROC_NAME);

        RowMapper mapper = new MyRowMapper();
        declareParameter(new SqlReturnResultSet("Return Value", mapper));
        declareParameter(new SqlParameter("FromDate", Types.VARCHAR));
        declareParameter(new SqlParameter("ToDate",Types.VARCHAR));
        compile();

    }

    public List execute(String FromDate,String ToDate) {
        Map inputs = new HashMap();
        inputs.put("FromDate",FromDate);
        inputs.put("ToDate",ToDate);
        Map map = super.execute(inputs);
        if (map != null && map.size() > 0) {
            return (List) map.get("Return Value");
        } else {
            return new ArrayList();
        }


    }


    private class MyRowMapper implements RowMapper<LoadOnDemand> {
        public LoadOnDemand mapRow(ResultSet rs, int rowNum) throws SQLException {
            LoadOnDemand l = new LoadOnDemand();
//              f.setDay(rs.getInt("ContractDay"));
            l.setInternalQuantity(rs.getInt("DVaznTon"));
            l.setExportalQuantitiy(rs.getInt("SVaznTon"));
            l.setInternalValue(rs.getDouble("DArzeshMillion"));
            l.setExternalValue(rs.getDouble("SArzeshMillion"));
            l.setInternalBuyersCount(rs.getInt("DBuyers"));
            l.setExternalBuyersCount(rs.getInt("SBuyers"));
            l.setInternalSellersCount(rs.getInt("DSellers"));
            l.setExternalSellersCount(rs.getInt("SSellers"));
            l.setInternalGoodsCount(rs.getInt("DSymbols"));
            l.setExternalGoodsCount(rs.getInt("SSymbols"));
            l.setTablo(rs.getString("GrouhAsli"));
            return l;
        }
    }



}

///追加した////

私のサンプルSP:

CREATE PROCEDURE [dbo].[sps_Test1]

WITH RECOMPILE      
AS

SELECT *

FROM dbo.tbl1

SELECT *

FROM dbo.tbl2
4

1 に答える 1

0

複数のテーブルを処理できませんでした。unionまたはを使用して、2 つのテーブルを 1 つに結合できます。unionAll

CREATE PROCEDURE [dbo].[sps_Test1]

WITH RECOMPILE      
AS

SELECT *

FROM dbo.tbl1
UNION
SELECT *

FROM dbo.tbl2
于 2013-04-08T12:10:37.887 に答える