欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

JDBC PreparedStatement Like参数报错解决方案

时间:2021-05-03 09:59:02|栏目:JAVA代码|点击:

由于我们的项目不大,所以刚开始决定时我为了省事想用SSH,可是后来觉得只有Struts2好了,后来的查询等数据库操作我自己写方法不行了嘛!

刚才写一个公共查询的方法,在增加参数时出了点错误,就是使用模糊查询时犯晕了。

我写的方法如下:

/** 
 * @说明 执行一条查询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(); // 执行查询,返回结果接集合 
    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 '%?%'",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 ?",para);    
  for (Object[] o : list) { 
    for (Object ob : o) { 
      System.out.print(ob + "-"); 
    } 
    System.out.println(); 
  } 
} 

就这么简单,闲话不说了!

上一篇:SpringBoot如何实现starter原理详解

栏    目:JAVA代码

下一篇:基于Spring boot @Value 注解注入属性值的操作方法

本文标题:JDBC PreparedStatement Like参数报错解决方案

本文地址:http://www.codeinn.net/misctech/113476.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有