zoukankan      html  css  js  c++  java
  • Java中使用PrepateStatement并且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%'  

    引用连接:点击打开链接

  • 相关阅读:
    移动终端app测试点总结
    Appium+Java(一) Windows环境搭建篇
    BeanShell用法汇总(部分摘抄至网络)【转】
    JVM的GC实现详解
    JVM的GC理论详解
    JVM的栈内存
    JVM的基本结构
    JVM的生命周期
    JVM的启动流程
    JVM的粗略简述
  • 原文地址:https://www.cnblogs.com/archermeng/p/7537553.html
Copyright © 2011-2022 走看看