Jason ---分享,共同进步

激情成就梦想,努力创造未来
随笔 - 53, 文章 - 1, 评论 - 45, 引用 - 0
数据加载中……

PreparedStatement 使用like 模糊查询

PreparedStatement 使用like

在使用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了。
一般情况下,我总是潜意识的认定了?就是取代所指定的参数,但是实际上我们可以对指定的参数进行了一定的包装之后再传给?,比如这里我们在参数的前后都加了一个%,然后再传给?   

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%'

posted on 2008-03-03 09:35 agun 阅读(9314) 评论(12)  编辑  收藏 所属分类: java 基础

评论

# re: PreparedStatement 使用like 模糊查询  回复  更多评论   

非常非常感谢。
问题解决了
2008-08-21 14:28 | 唐林峰

# re: PreparedStatement 使用like 模糊查询  回复  更多评论   

呵呵,能解决问题就好,有什么问题大家可以多交流.互相学习.
2008-08-22 08:32 | agun

# re: PreparedStatement 使用like 模糊查询  回复  更多评论   

受益良多,正为这个问题烦恼呢
2009-02-05 16:27 | Luna

# re: PreparedStatement 使用like 模糊查询  回复  更多评论   

呵呵 ,互相学习
2009-02-05 16:57 | agun

# re: PreparedStatement 使用like 模糊查询  回复  更多评论   

学习了,谢谢
2009-02-09 11:44 | 123

# re: PreparedStatement 使用like 模糊查询  回复  更多评论   

总是不注意小的细节问题
2009-02-13 15:54 | 菜鸟中的菜鸟

# re: PreparedStatement 使用like 模糊查询  回复  更多评论   

真是太犀利了,有时候我们的思维就陷在一个死角里,要有人点拨一下,才能钻出来。 受益匪浅啊.
2010-05-11 19:18 | 王智群

# re: PreparedStatement 使用like 模糊查询[未登录]  回复  更多评论   

根本就解决不了问题
我试过好几种方法 都不可以
2011-12-19 23:25 | Lee

# re: PreparedStatement 使用like 模糊查询[未登录]  回复  更多评论   

怎么不可以了,是可以?
2011-12-22 08:48 | agun

# re: PreparedStatement 使用like 模糊查询  回复  更多评论   

学习了~~ 受益匪浅
2012-01-11 20:50 | 11

# re: PreparedStatement 使用like 模糊查询  回复  更多评论   

谢谢。。。。
2012-07-06 20:29 | 严宁云

# re: PreparedStatement 使用like 模糊查询[未登录]  回复  更多评论   

为什么我的不能解决问题啊,查询失败。。
2014-03-18 18:16 | 新手

只有注册用户登录后才能发表评论。


网站导航: