当前位置:首页 > 开发 > 编程语言 > 编程 > 正文

JDBC中PreparedStatement中Like后面的参数

发表于: 2012-04-09   作者:cuisuqiang   来源:转载   浏览次数:
摘要: 好久没发博客,因为解决一些技术问题后要做业务开发。 欢迎大家访问我的博客来和我交流:http://cuisuqiang.iteye.com/ 可是最近麻烦又来了,在还没有彻底结束上一个之前,领导把我安排到了新的岗位,我那个郁闷啊。   由于我们的项目不大,所以刚开始决定时我为了省事想用SSH,可是后来觉得只有Struts2好了,后来的查询等数据库操作我自己写方法不行了嘛! 刚才

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

欢迎大家访问我的博客来和我交流: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.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();
	}
}

 

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

 

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

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

 

JDBC中PreparedStatement中Like后面的参数

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
 MySQL JDBC Driver   常用的有两个,一个是gjt(Giant Java Tree)组织提供的mysql驱动,其JDBC
首先说明一点id 17的位置fdzyj我是存储了一个空格 可以看出'%%'和'% %'是不一样的空格也是个字符 所
摘要 学习如何在Java桌面应用中部署基于Apache Derby的Java DB。该文章使用住址名册例子来向你演示
之前看JDBC规范的时候对PreparedStatement只是简单的知道会进行sql预编译,能提高性能。具体原理也
在这一节讲解下like指令,其实这个方法在sql server中功能还是比较强大的,它有时在查询sql语句中能
Intent i = new Intent(B.this, C.class); i.setFlags(Intent.FLAG_ACTIVITY_NO_HISTORY); //什么含
Intent i = new Intent(B.this, C.class); i.setFlags(Intent.FLAG_ACTIVITY_NO_HISTORY); //什么含
find手册中对time的解释: 以 atime 为例: -atime n File was last accessed n*24 hours ago. When f
为什么要使用PreparedStatement? 一、通过PreparedStatement提升性能 Statement主要用于执行静态SQ
一、什么是PreparedStatement 参阅Java API文档,我们可以知道,PreparedStatement是Statement的子
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号