国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

使用sqlserver官方驅動包調用存儲過程遇到的坑及解決方法

瀏覽:132日期:2023-03-06 14:25:34

和外部系統做對接,對方提供了一個存儲過程,對方為sqlserver數據庫,我方為oracle數據庫。
需求簡單來說就是調用對方的存儲過程獲得結果,轉儲到我方庫,后續在對數據進行處理。

我寫了個代碼片段做測試,用jdbc來調用對方的存儲過程,可是在調用后就直接報錯了,錯誤信息如下

com.microsoft.sqlserver.jdbc.SQLServerException: 該語句沒有返回結果集

我就不理解了,為啥用數據庫連接工具調就沒問題呢?是有結果集的呀。

瘋狂找資料,找帖子。最后終于是找到了。

解決方法:

  1. 換驅動包。對方數據庫是SQL server2008,我用的是 sqljdbc4-4.0 。直接換了第三方開源的SQL Server數據庫的JDBC驅動程序 jtds1.2。問題解決,調用存儲過程的時候不再出錯。
  2. 在存儲過程首行添加 set nocount on (這個我沒實驗,因為存儲過程沒在我手里,操作不到)

最后記錄一段jdbc調用存儲結構的代碼,一個參數,返回結果集

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class Test {
    final static String SERVERURL = "jdbc:jtds:sqlserver://127.0.0.1:1433;DatabaseName=XXX";
    final static String SERVERDriver = "net.sourceforge.jtds.jdbc.Driver";
    final static String SERVERUSERNAME = "username";
    final static String SERVERPASSWORD = "password";
 
    public static void main(String[] args) {
try {
    //調用存儲過程
    Class.forName(SERVERDriver);
    Connection conn = DriverManager.getConnection(SERVERURL, SERVERUSERNAME, SERVERPASSWORD);
    System.out.println("sql server連接成功");
    String call = "{call 存儲過程名稱(?)}";
    CallableStatement callableStatement = conn.prepareCall(call);
    callableStatement.setString(1, "2022-10-13");
    ResultSet rs = callableStatement.executeQuery();
    while(rs.next()) {
System.out.println(rs.getString("aaa"));
System.out.println(rs.getString("bbb"));
System.out.println(rs.getString("ccc"));
System.out.println(rs.getString("ddd"));
    }
    callableStatement.close();
    conn.close();
} catch (Exception e) {
    e.printStackTrace();
}
    }
}

到此這篇關于用sqlserver官方驅動包調用存儲過程遇到的一個坑的文章就介紹到這了,更多相關sqlserver官方驅動包調用存儲過程內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MsSQL
主站蜘蛛池模板: 华池县| 长白| 根河市| 巴塘县| 景德镇市| 浑源县| 南京市| 宜良县| 河源市| 鄱阳县| 前郭尔| 周口市| 奉化市| 聂荣县| 桦甸市| 霍林郭勒市| 新闻| 铜山县| 钟山县| 攀枝花市| 景宁| 通江县| 万全县| 汉沽区| 宝清县| 江阴市| 蒲城县| 阳原县| 嘉峪关市| 雅江县| 佛学| 万安县| 鄂托克前旗| 台南县| 浦北县| 高台县| 三门县| 湘阴县| 德江县| 黄陵县| 三穗县|