做项目遇到了个奇怪的问题,项目里面要对商品、账户、进行分别的多条件查询,于是我就采用动态多条件分页查询,起初在做账户部分的时候Mybatis是这样写的

<!-- 动态多条件分页查询 -->
<select id="searchPageUseDyc" parameterType="page" resultMap="accountResultMap">
select acc_id,acc_login,acc_name,acc_pass
from account
<where>
<if test="paramsEntity.accId!=null">
and acc_id like #{paramsEntity.accId}
</if>
<if test="paramsEntity.accLogin!=null">
and acc_login like #{paramsEntity.accLogin}
</if>
<if test="paramsEntity.accName!=null">
and acc_name like #{paramsEntity.accName}
</if>
<if test="paramsEntity.accPass!=null">
and acc_pass like #{paramsEntity.accPass}
</if>
</where>
limit #{start},#{rows}
</select>

like 后面直接跟 #{paramsEntity.accName} 不需要添加单引号

然后完成商品查询的时候我一样写了一套

<!-- 动态分页多条件查询(找内容) -->
<select id="searchPageUseDyc" parameterType="page" resultMap="goodsResultMap">
select goods_Id,goods_name,goods_unit,goods_type,goods_color,goods_store,goods_limit,goods_commission,goods_producer,goods_remark,goods_sel_price,goods_buy_price
from goods
<where>
<if test="paramsEntity.goodsId!=null">
        and goods_Id like ${paramsEntity.goodsId}
      </if>
<if test="paramsEntity.goodsName!=null">
        and goods_name like ${paramsEntity.goodsName}
      </if>
<if test="paramsEntity.goodsUnit!=null">
        and goods_unit like ${paramsEntity.goodsUnit}
      </if>
<if test="paramsEntity.goodsType!=null">
        and goods_type like ${paramsEntity.goodsType}
      </if>
<if test="paramsEntity.goodsColor!=null">
        and goods_color like ${paramsEntity.goodsColor}
      </if>
<if test="paramsEntity.goodsStore!=null">
        and goods_store like ${paramsEntity.goodsStore}
      </if>
<if test="paramsEntity.goodsLimit!=null">
        and goods_limit like ${paramsEntity.goodsLimit}
      </if>
<if test="paramsEntity.goodsCommission!=null">
        and goods_commission like ${paramsEntity.goodsCommission}
      </if>
<if test="paramsEntity.goodsProducer!=null">
        and goods_producer like ${paramsEntity.goodsProducer}
      </if>
<if test="paramsEntity.goodsRemark!=null">
        and goods_remark like ${paramsEntity.goodsRemark}
      </if>
<if test="paramsEntity.goodsSelPrice!=null">
        and goods_sel_price like ${paramsEntity.goodsSelPrice}
      </if>
<if test="paramsEntity.goodsBuyPrice!=null">
        and goods_buy_price like ${paramsEntity.goodsBuyPrice}
      </if>
</where>
limit #{start},#{rows}
</select>

但是运行报错了!!!

错误信息You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '%% limit 0,3' at line 3

然后我就给单引号添加上了,然后居然就成了,代码这样子

<!-- 动态分页多条件查询(找内容) -->
<select id="searchPageUseDyc" parameterType="page" resultMap="goodsResultMap">
select goods_Id,goods_name,goods_unit,goods_type,goods_color,goods_store,goods_limit,goods_commission,goods_producer,goods_remark,goods_sel_price,goods_buy_price
from goods
<where>
<if test="paramsEntity.goodsId!=null">
        and goods_Id like '${paramsEntity.goodsId}'
      </if>
<if test="paramsEntity.goodsName!=null">
        and goods_name like '${paramsEntity.goodsName}'
      </if>
<if test="paramsEntity.goodsUnit!=null">
        and goods_unit like '${paramsEntity.goodsUnit}'
      </if>
<if test="paramsEntity.goodsType!=null">
        and goods_type like '${paramsEntity.goodsType}'
      </if>
<if test="paramsEntity.goodsColor!=null">
        and goods_color like '${paramsEntity.goodsColor}'
      </if>
<if test="paramsEntity.goodsStore!=null">
        and goods_store like '${paramsEntity.goodsStore}'
      </if>
<if test="paramsEntity.goodsLimit!=null">
        and goods_limit like '${paramsEntity.goodsLimit}'
      </if>
<if test="paramsEntity.goodsCommission!=null">
        and goods_commission like '${paramsEntity.goodsCommission}'
      </if>
<if test="paramsEntity.goodsProducer!=null">
        and goods_producer like '${paramsEntity.goodsProducer}'
      </if>
<if test="paramsEntity.goodsRemark!=null">
        and goods_remark like '${paramsEntity.goodsRemark}'
      </if>
<if test="paramsEntity.goodsSelPrice!=null">
        and goods_sel_price like '${paramsEntity.goodsSelPrice}'
      </if>
<if test="paramsEntity.goodsBuyPrice!=null">
        and goods_buy_price like '${paramsEntity.goodsBuyPrice}'
      </if>
</where>
limit #{start},#{rows}
</select>

然后我就去查文档,光放文档给出的也是不用加单引号的!!

<select id=”findActiveBlogLike”
  parameterType=”Blog” resultType=”Blog”>
  SELECT * FROM BLOG
  <where>
    <if test=”state != null”>
      state = #{state}
    </if>
    <if test=”title != null”>
      AND title like #{title}
    </if>
    <if test=”author != null and author.name != null”>
      AND title like #{author.name}
    </if>
  </where>
</select>

我的问题还真不知道出在哪里!!!奇了怪了,有空再去搞清楚吧 !!!!

MyBatis做动态模糊查询时,like后面要不要加单引号??的更多相关文章

  1. Mybatis使用MySQL模糊查询时输入中文检索不到结果怎么办--转自http://www.jb51.net/article/88236.htm

    这篇文章主要介绍了Mybatis使用MySQL模糊查询时输入中文检索不到结果的解决办法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下   项目开发中,在做Mybatis动态查询时,遇到了 ...

  2. mybatis做like模糊查询

    http://www.cnblogs.com/cyttina/p/3894428.html

  3. Mybatis使用MySQL进行模糊查询时输入中文检索不到结果

    Mybatis使用MySQL进行模糊查询时输入中文检索时,需要在jdbcURL后增加参数   ?useUnicode=true&characterEncoding=UTF-8

  4. input动态模糊查询的实现方式

    最近在用jQuery实现动态模糊查询的时候,找了挺久都没有找到像Vue.js的watch属性这么好用的动态模糊查询方法.就分享一下目前遇到的坑和可以实现动态查询的几种方式. 1.jQuery的chan ...

  5. Mybatis注解开发模糊查询

    Mybatis注解开发模糊查询 一般在使用mybatis时都是采用xml文件保存sql语句 这篇文章讲一下在使用mybatis的注解开发时,如何进行模糊查询 模糊查询语句写法(在@Select注解中) ...

  6. 一个jpa动态模糊查询的实现

    最近一直在是用spring data jpa,使用起来确实方便,如果是单表的操作基本上通过方法名都可以实现,下面是一个 Specification 实现动态模糊查询的例子这个查询是通过JpaSpeci ...

  7. Hibernate使用createSqlQuery进行模糊查询时找不到数据

    1. 首先明确一点,使用createSqlQuery如下两种方式的占位符都可以使用,这个在官方的文档可以查到. 注意使用模糊查询时,赋值两边不可以添加单引号. Query query = sess.c ...

  8. 【mybatis】mybatis自定义动态字段查询,mybatis实现动态字段查询,如果某个条件为null,则不查询某个字段,否则就查询某个字段

    mybatis实现动态字段查询,如果某个条件为null,则不查询某个字段,否则就查询某个字段 先看一下 怎么实现动态的自定义字段查询: 例如: 而field 就是数据表中的某一个字段 String f ...

  9. Mybatis框架的模糊查询(多种写法)、删除、添加(四)

    学习Mybatis这么多天,那么我给大家分享一下我的学习成果.从最基础的开始配置. 一.创建一个web项目,看一下项目架构 二.说道项目就会想到需要什么jar 三.就是准备大配置链接Orcl数据库 & ...

随机推荐

  1. socket介绍(webService适用场景)

    1.使用场景         - 不同的移动客户端访问      - 需要访问第三方的项目 2.访问第三方应用的方式      ISO的七层模型  : 物理层.数据链路层.网络层.传输层.表示层.会话 ...

  2. scrapy实战

    采用scrapy实现对股票网站的爬取 功能描述: 技术路线:scrapy 目标:获取上交所和深交所所有股票名称和交易信息并存储 实例编写: 步骤1:建立工程和spider爬虫模板 步骤2:编写spid ...

  3. Git Base 操作(二)

    1. 撤销修改 (1) 当改乱了工作区(working directory)某个文件的内容,想直接丢弃工作区中的修改时,用命令git checkout -- file. (2) 当不但改乱了工作区某个 ...

  4. CSU 1779: 错误的算法【矩阵/模拟】

    Description 有道题目是这样的: 输入一个 n 行 m 列网格,找一个格子,使得它所在的行和列中所有格子的数之和最大.如果答 案不唯一,输出任意解即可.比如,在下面的例子中,最优解是(1,3 ...

  5. Web模糊测试工具Powerfuzzer

    Web模糊测试工具Powerfuzzer   Powerfuzzer是Kali Linux自带的一款Web模糊测试工具.该工具基于各种开源模糊测试工具构建,集成了大量安全信息.该工具高度智能化,它能根 ...

  6. 如何使用Ext.create() 调用一个窗体

    Ext.define("Scripts.Code.QM.OutgoingQuality.OQC.ReinspRequest.view.DefectContentsDetailInfoWind ...

  7. SecureCRT设置和Xshell一样的快速命令集(使用快捷键输入命令和密码)

    编辑想要的命令 提示:想要回车直接输入[\r]

  8. main函数参数

    方法1. C/C++语言中的main函数,经常带有参数argc,argv,如下: int main(int argc, char** argv) int main(int argc, char* ar ...

  9. 在Bonobo服务器里创建Repository(库)

    新建Repository步骤如下: 点击“库”链接,进入“库管理”页面,如下图所示: 在“库管理”页面点击“创建新库”按钮,进入“创建新库”页面,如下图所示: 点击“建立”按钮,会进入“库管理”页面, ...

  10. eclipse中mybatis generator插件的安装与使用,实现自动生成代码

    git地址:https://github.com/mybatis/generator 下载后解压: 选择任意一个版本的jar放到eclipse的features目录下即可 选择任意一个版本的jar放到 ...