Java中使用PrepateStatement并且like模糊查询
来源:互联网 发布:svn和git的区别 知乎 编辑:程序博客网 时间:2024/06/17 13:11
在使用PreparedStatement进行模糊查询的时候废了一番周折,以前一直都没有注意这个问题。一般情况下我们进行精确查询,sql语句类似:select * from table where name =?,然后调用PreparedStatement的setString等方法给?指定值。那么模糊查询的时候应该怎么写呢?我首先尝试了:select *from customer where name like ‘%?%’。
此时程序报错,因为?被包含在了单引号中,PreparedStatement并不视它为一个参数。后来上网查了相关的一些资料,发现可以这样写select * from table where name like?;但是在指定参数的时候把?指定为”%”+name+”%”,name是指定的查询条件。这样就OK了。
一般情况下,我总是潜意识的认定了?就是取代所指定的参数,但是实际上我们可以对指定的参数进行了一定的包装之后再传给?,比如这里我们在参数的前后都加了一个%,然后再传给?
此时程序报错,因为?被包含在了单引号中,PreparedStatement并不视它为一个参数。后来上网查了相关的一些资料,发现可以这样写select * from table where name like?;但是在指定参数的时候把?指定为”%”+name+”%”,name是指定的查询条件。这样就OK了。
一般情况下,我总是潜意识的认定了?就是取代所指定的参数,但是实际上我们可以对指定的参数进行了一定的包装之后再传给?,比如这里我们在参数的前后都加了一个%,然后再传给?
String expr = "select * from table where url like?"; pstmt =con.prepareStatement(expr); String a="a"; pstmt.setString(1,"%"+a+"%");//自动添加单引号 (包装后的参数) pstmt.execute(); System.out.println(pstmt.toString());//打印sql //会默认生成sql: select *from table where url like '%http%'
- Java中使用PrepateStatement并且like模糊查询
- Java中使用PrepateStatement并且like模糊查询
- Java中使用PrepateStatement并且like模糊查询
- Java中使用PrepateStatement并且like模糊查询
- ibatis中使用like模糊查询
- ibatis中使用like模糊查询
- Mybatis中使用like模糊查询
- ibatis中使用like模糊查询
- ibatis中使用like模糊查询
- ibatis中使用like模糊查询
- ibatis中使用like模糊查询
- ibatis中使用like模糊查询
- ibatis中使用like模糊查询
- 【转】ibatis中使用like模糊查询
- ibatis中使用like模糊查询
- 模糊查询中Like的使用
- Mybatis中使用like和%模糊查询
- ibatis中使用like模糊查询
- linux 库文件 生成与使用
- Android平台下流媒体.视频播放器(功能介绍及源码解析,附源码) SeeJoPlayer
- 电梯掉落 自救
- cdev_alloc和cdev_add
- Silverlight 4已经不再包含ImplicitStyleManager类。使用Theme
- Java中使用PrepateStatement并且like模糊查询
- @Rsync文件同步服务器的简介&安装和配置@
- [转]tcp不能保证数据传输的万无一失
- vs2008调试c++ dll文件
- UML图例
- oracle 远程连接超时问题
- 做一个导航栏,单击内容显示高亮的效果
- STM32系列产品命名规则
- 去掉vs2010英文版中文注释的波浪线