JDBC中PreparedStatement中Like后面的参数

编程技术  /  houtizong 发布于 2年前   148

好久没发博客,因为解决一些技术问题后要做业务开发。

欢迎大家访问我的博客来和我交流:http://cuisuqiang.iteye.com/

可是最近麻烦又来了,在还没有彻底结束上一个之前,领导把我安排到了新的岗位,我那个郁闷啊。

 

由于我们的项目不大,所以刚开始决定时我为了省事想用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.NullPointerExceptionat 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();}}

 

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

 

请您到ITEYE看我的原创:http://cuisuqiang.iteye.com

或支持我的个人博客,地址:http://www.javacui.com

 

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!

留言需要登陆哦

技术博客集 - 网站简介:
前后端技术:
后端基于Hyperf2.1框架开发,前端使用Bootstrap可视化布局系统生成

网站主要作用:
1.编程技术分享及讨论交流,内置聊天系统;
2.测试交流框架问题,比如:Hyperf、Laravel、TP、beego;
3.本站数据是基于大数据采集等爬虫技术为基础助力分享知识,如有侵权请发邮件到站长邮箱,站长会尽快处理;
4.站长邮箱:[email protected];

      订阅博客周刊 去订阅

文章归档

文章标签

友情链接

Auther ·HouTiZong
侯体宗的博客
© 2020 zongscan.com
版权所有ICP证 : 粤ICP备20027696号
PHP交流群 也可以扫右边的二维码
侯体宗的博客