JDBC PreparedStatement Like参数报错解决方案
程序员文章站
2022-04-06 22:33:12
由于我们的项目不大,所以刚开始决定时我为了省事想用ssh,可是后来觉得只有struts2好了,后来的查询等数据库操作我自己写方法不行了嘛!刚才写一个公共查询的方法,在增加参数时出了点错误,就是使用模糊...
由于我们的项目不大,所以刚开始决定时我为了省事想用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(); } }
就这么简单,闲话不说了!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。