溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JDBC PreparedStatement Like參數報錯的解決方法

發(fā)布時間:2020-11-02 15:08:45 來源:億速云 閱讀:257 作者:Leah 欄目:開發(fā)技術

這篇文章運用簡單易懂的例子給大家介紹JDBC PreparedStatement Like參數報錯的解決方法,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

/** 
 * @說明 執(zhí)行一條查詢SQL語句,可以帶參數 
 */ 
public static List<Object[]> excuteQuery(String sql, Object[] objs) { 
  Connection conn = null; 
  PreparedStatement psta = null; 
  ResultSet rs = null; 
  List<Object[]> iResult = null; 
  Object[] objArr = null; 
  try { 
    conn = getConn(); // 得到鏈接 
    PreparedStatement state = conn.prepareStatement(sql); 
    if(null != objs){ 
      for (int i = 0; i < objs.length; i++) { 
        state.setObject(i + 1, objs[i]); 
      } 
    } 
    ResultSet resultSet = state.executeQuery(); // 執(zhí)行查詢,返回結果接集合 
    iResult = new ArrayList<Object[]>(); 
    int count = resultSet.getMetaData().getColumnCount(); // 一共有多少列數據 
    while (resultSet.next()) { 
      objArr = new Object[count]; 
      for (int i = 1; i <= count; i++) { 
        objArr[i - 1] = resultSet.getObject(i); // 增加到返回的集合中 
      } 
      iResult.add(objArr); 
    } 
  } catch (Exception e) { 
    e.printStackTrace(); 
    iResult = null; 
  } finally { 
    try { 
      if (rs != null) { 
        rs.close(); 
      } 
      if (psta != null) { 
        psta.close(); 
      } 
      if (conn != null) { 
        conn.close(); 
      } 
    } catch (Exception e2) { 
 
    } 
  } 
  return iResult; 
} 

后來我輸入這樣的一個參數進行查詢:

public static void main(String[] args) { 
  Object[] para = new Object[]{"c"}; 
  List<Object[]> list = excuteQuery("select * from s_user t where t.userName like '%&#63;%'",para);    
  for (Object[] o : list) { 
    for (Object ob : o) { 
      System.out.print(ob + "-"); 
    } 
    System.out.println(); 
  } 
} 

結果報錯如下:

java.sql.SQLException: Parameter index out of range (1 > number of parameters, which is 0). 
  at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1056) 
  at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:957) 
  at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:927) 
  at com.mysql.jdbc.PreparedStatement.checkBounds(PreparedStatement.java:3279) 
  at com.mysql.jdbc.PreparedStatement.setInternal(PreparedStatement.java:3263) 
  at com.mysql.jdbc.PreparedStatement.setString(PreparedStatement.java:4087) 
  at com.mysql.jdbc.PreparedStatement.setObject(PreparedStatement.java:3513) 
  at org.apache.commons.dbcp.DelegatingPreparedStatement.setObject(DelegatingPreparedStatement.java:166) 
  at com.nms.common.db.ConnectionManager.excuteQuery(ConnectionManager.java:86) 
  at com.nms.common.db.ConnectionManager.main(ConnectionManager.java:20) 
Exception in thread "main" java.lang.NullPointerException 
  at com.nms.common.db.ConnectionManager.main(ConnectionManager.java:21) 

后來才知道,模糊查詢時要這樣寫:

public static void main(String[] args) { 
  Object[] para = new Object[]{"%c%"}; 
  List<Object[]> list = excuteQuery("select * from s_user t where t.userName like &#63;",para);    
  for (Object[] o : list) { 
    for (Object ob : o) { 
      System.out.print(ob + "-"); 
    } 
    System.out.println(); 
  } 
} 

關于JDBC PreparedStatement Like參數報錯的解決方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI