Spring 的jdbcTemplate 調用預存程序

來源:互聯網
上載者:User

JdbcTemplate 調用預存程序

 

Java代碼
 
  1. /**程式碼片段*/  
  2. //5個輸入參數,3個輸出參數   
  3. String sql = "{call GENERATEORDERS_P(?,?,?,?,?,?,?,?)}";   
  4.                                
  5. final String company_id = result.get("F_COMPANY_ID").toString();           // 公司ID
      
  6. final String competition_id = result.get("F_COMPETITION_ID").toString();   // 比賽ID
      
  7. final String current_phase = result.get("F_CURRENT_PHASE").toString();     // 當前周期
      
  8. final String market_scope_id = result.get("F_MARKET_SCOPE_ID").toString(); // 市場ID
      
  9. final String market_loca_id = result.get("F_MARKET_LOCA_ID").toString();   // 產品類型ID
      
  10.   
  11. Map mapR = (Map) getJdbcTemplate().execute(sql,new CallableStatementCallback() {   
  12.             public Object doInCallableStatement(CallableStatement cs)throws SQLException,DataAccessException {   
  13.                 cs.setString(1, current_phase);    // 輸入參數
      
  14.                 cs.setString(2, competition_id);   // 輸入參數
      
  15.                 cs.setString(3, market_scope_id);  // 輸入參數
      
  16.                 cs.setString(4, market_loca_id);   // 輸入參數
      
  17.                 cs.setString(5, company_id);       // 輸入參數
      
  18.                 cs.registerOutParameter(6,Types.VARCHAR);//輸出參數
      
  19.                 cs.registerOutParameter(7,Types.VARCHAR);//輸出參數
      
  20.                 cs.registerOutParameter(8,Types.VARCHAR);//輸出參數
      
  21.                 cs.execute();   
  22.                 Map map = new HashMap();   
  23.                 map.put("RESULT", cs.getString(6));       // 訂單數量
      
  24.                 map.put("F_PRICE", cs.getString(7));      // 訂單價格
      
  25.                 map.put("F_CPUT_MOD_ID", cs.getString(8));// 產品型號ID
      
  26.                 return map;   
  27.             }   
  28.         });  
/**程式碼片段*///5個輸入參數,3個輸出參數String sql = "{call GENERATEORDERS_P(?,?,?,?,?,?,?,?)}";final String company_id = result.get("F_COMPANY_ID").toString();           // 公司IDfinal String competition_id = result.get("F_COMPETITION_ID").toString();   // 比賽IDfinal String current_phase = result.get("F_CURRENT_PHASE").toString();     // 當前周期final String market_scope_id = result.get("F_MARKET_SCOPE_ID").toString(); // 市場IDfinal String market_loca_id = result.get("F_MARKET_LOCA_ID").toString();   // 產品類型IDMap mapR = (Map) getJdbcTemplate().execute(sql,new CallableStatementCallback() {public Object doInCallableStatement(CallableStatement cs)throws SQLException,DataAccessException {cs.setString(1, current_phase);    // 輸入參數cs.setString(2, competition_id);   // 輸入參數cs.setString(3, market_scope_id);  // 輸入參數cs.setString(4, market_loca_id);   // 輸入參數cs.setString(5, company_id);       // 輸入參數cs.registerOutParameter(6,Types.VARCHAR);//輸出參數cs.registerOutParameter(7,Types.VARCHAR);//輸出參數cs.registerOutParameter(8,Types.VARCHAR);//輸出參數cs.execute();Map map = new HashMap();map.put("RESULT", cs.getString(6));       // 訂單數量map.put("F_PRICE", cs.getString(7));      // 訂單價格map.put("F_CPUT_MOD_ID", cs.getString(8));// 產品型號IDreturn map;}});

 

 

 execute方法返回的是一個Object對象,在這裡我封裝了一個Map對象返回。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.