欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JDBC PreparedStatement Like參數(shù)報錯解決方案

 更新時間:2020年10月31日 15:16:01   作者:cuisuqiang  
這篇文章主要介紹了JDBC PreparedStatement Like參數(shù)報錯解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

由于我們的項目不大,所以剛開始決定時我為了省事想用SSH,可是后來覺得只有Struts2好了,后來的查詢等數(shù)據(jù)庫操作我自己寫方法不行了嘛!

剛才寫一個公共查詢的方法,在增加參數(shù)時出了點錯誤,就是使用模糊查詢時犯暈了。

我寫的方法如下:

/** 
 * @說明 執(zhí)行一條查詢SQL語句,可以帶參數(shù) 
 */ 
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í)行查詢,返回結(jié)果接集合 
    iResult = new ArrayList<Object[]>(); 
    int count = resultSet.getMetaData().getColumnCount(); // 一共有多少列數(shù)據(jù) 
    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; 
} 

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

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

結(jié)果報錯如下:

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 ?",para);    
  for (Object[] o : list) { 
    for (Object ob : o) { 
      System.out.print(ob + "-"); 
    } 
    System.out.println(); 
  } 
} 

就這么簡單,閑話不說了!

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JDBC PreparedStatement Like參數(shù)報錯解決方案

    JDBC PreparedStatement Like參數(shù)報錯解決方案

    這篇文章主要介紹了JDBC PreparedStatement Like參數(shù)報錯解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-10-10
  • java實現(xiàn)代碼統(tǒng)計小程序

    java實現(xiàn)代碼統(tǒng)計小程序

    這篇文章主要為大家詳細介紹了java實現(xiàn)代碼統(tǒng)計小程序,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • 一文詳解Spring是怎么讀取配置Xml文件的

    一文詳解Spring是怎么讀取配置Xml文件的

    這篇文章主要介紹了一文詳解Spring是怎么讀取配置Xml文件的,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下
    2022-08-08
  • 一篇文章帶你入門Java多線程

    一篇文章帶你入門Java多線程

    這篇文章主要介紹了java多線程編程實例,分享了幾則多線程的實例代碼,具有一定參考價值,加深多線程編程的理解還是很有幫助的,需要的朋友可以參考下
    2021-08-08
  • SpringBoot @Import與@Conditional注解使用詳解

    SpringBoot @Import與@Conditional注解使用詳解

    在了解spring boot自動配置原理前,再來了解下兩個注解@Import注解和@Conditional注解,@Conditional是Spring4新提供的注解,它的作用是按照一定的條件進行判斷,滿足條件給容器注冊bean
    2022-10-10
  • Spring Date jpa 獲取最新一條數(shù)據(jù)的實例代碼

    Spring Date jpa 獲取最新一條數(shù)據(jù)的實例代碼

    這篇文章主要介紹了Spring Date jpa 獲取最新一條數(shù)據(jù)的實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • Java設(shè)計模式之java策略模式詳解

    Java設(shè)計模式之java策略模式詳解

    這篇文章主要介紹了Java經(jīng)典設(shè)計模式之策略模式,簡單說明了策略模式的概念、原理并結(jié)合實例形式分析了java策略模式的具有用法與相關(guān)注意事項,需要的朋友可以參考下
    2021-09-09
  • java中instanceof和getClass()的區(qū)別分析

    java中instanceof和getClass()的區(qū)別分析

    本篇文章介紹了,在java中instanceof和getClass()的區(qū)別分析。需要的朋友參考下
    2013-04-04
  • MybatisPlus之時間處理問題

    MybatisPlus之時間處理問題

    在數(shù)據(jù)庫設(shè)計時,阿里巴巴編碼規(guī)約建議使用gmt_create和gmt_modified命名時間字段,并設(shè)置為datetime類型,本文介紹了兩種自動填充時間字段的實現(xiàn)方式:SQL級別和代碼級別(使用MyBatis?Plus),SQL級別通過設(shè)置默認值和更新值為CURRENT_TIMESTAMP
    2024-09-09
  • springboot 中 inputStream 神秘消失之謎(終破)

    springboot 中 inputStream 神秘消失之謎(終破)

    這篇文章主要介紹了springboot 中 inputStream 神秘消失之謎,為了能夠把這個問題說明,我們首先需要從簡單的http調(diào)用說起,通過設(shè)置body等一些操作,具體實現(xiàn)代碼跟隨小編一起看看吧
    2021-08-08

最新評論