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

    1 String expr = "select * from  table where url like ?";
    2 pstmt = con.prepareStatement(expr);
    3 String a="a";
    4 pstmt.setString(1, "%"+a+"%");//自动添加单引号 (包装后的参数)
    5 pstmt.execute();
    6 System.out.println(pstmt.toString());//打印sql
    7 //会默认生成sql: select * from  table where url like '%http%'
  • 相关阅读:
    .NET视频学习总结
    hdu5288(2015多校1)OO’s Sequence
    【Go web开发之revel+mgo】第1章 述与环境
    Android获得当前系统时间、星期几、周几
    夯实Java:从面向对象说起
    centos7 安装nginx
    centos7 安装nginx
    centos7 安装nginx
    element-ui中cascader同时获取label和value值
    element-ui中cascader同时获取label和value值
  • 原文地址:https://www.cnblogs.com/fnlingnzb-learner/p/6015949.html
Copyright © 2011-2022 走看看