纯净、安全、绿色的下载网站

首页|软件分类|下载排行|最新软件|IT学院

当前位置:首页IT学院IT技术

MyBatis模糊查询mapper.xml写法 MyBatis的模糊查询mapper.xml的写法讲解

唯爱沁源   2021-09-30 我要评论
想了解MyBatis的模糊查询mapper.xml的写法讲解的相关内容吗唯爱沁源在本文为您仔细讲解MyBatis模糊查询mapper.xml写法的相关知识和一些Code实例欢迎阅读和指正我们先划重点:MyBatis,mapper,MyBatis模糊查询,mapper.xml下面大家一起来学习吧。

MyBatis模糊查询mapper.xml的写法

模糊查询语句不建议使用${}的方式还是建议采用MyBatis自带的#{}方式#{}是预加载的方式运行的比较安全${}方式可以用但是有SQL注入的风险!!!

1.直接传参

在controller类中

String id = "%"+ id +"%";
String name = "%"+ name +"%";
dao.selectByIdAndName(id,name);

在mapper.xml映射文件中

<select>
    select * from table wherer id=#{id} or name like #{name}
</select>

2.针对MySQL数据库的语句

采用concat()函数它可以将多个字符串连接成一个字符

<select>
    select * from table where name like concat('%',#{name},'%')
</select>

3.适用于所有数据库的则采用MyBatis的bind元素

public xx selectByLike(@Param("_name") String name);
<select id="selectByLike">
    <bind name="user_name" value="'%' + _name + '%'"/>
    select * from table where name like #{user_name}
</select>

其中_name为传递进来的参数bind元素的value属性将传进来的参数和 '%' 拼接到一起后赋给name属性的user_name之后可以在select语句中使用user_name这个变量。

bind元素也支持传递多个参数

public xx selectByLike(@Param("_name") String name, @Param("_note") String note);
<select id="selectByLike">
    <bind name="user_name" value="'%' + _name + '%'"/>
    <bind name="user_note" value="'%' + _note + '%'"/>
    select * from table where name like #{user_name} and note like #{user_note}
</select>

MyBatis在xml中模糊查询的常用的3种方式

<!-- ******************** 模糊查询的常用的3种方式:********************* -->
    <select id="getUsersByFuzzyQuery" parameterType="User" resultType="User">
        select <include refid="columns"/> from users
        <where>
            <!--
                方法一: 直接使用 % 拼接字符串
                注意:此处不能写成  "%#{name}%" ,#{name}就成了字符串的一部分,
                会发生这样一个异常: The error occurred while setting parameters,
                应该写成: "%"#{name}"%",即#{name}是一个整体,前后加上%
            -->
            <if test="name != null">
                name like "%"#{name}"%"
            </if>
            <!--方法二: 使用concat(str1,str2)函数将两个参数连接 -->
            <if test="phone != null">
                and phone like concat(concat("%",#{phone}),"%")
            </if>
            <!--方法三: 使用 bind 标签,对字符串进行绑定,然后对绑定后的字符串使用 like 关键字进行模糊查询 -->
            <if test="email != null">
                <bind name="pattern" value="'%'+email+'%'"/>
                and email like #{pattern}
            </if>
        </where>
    </select>

以上为个人经验希望能给大家一个参考也希望大家多多支持。


相关文章

猜您喜欢

  • Python基础-特殊方法 Python基础-特殊方法整理详解

    想了解Python基础-特殊方法整理详解的相关内容吗Zarten在本文为您仔细讲解Python基础-特殊方法的相关知识和一些Code实例欢迎阅读和指正我们先划重点:Python基础,Python特殊方法下面大家一起来学习吧。..
  • python倒计时 基于python写个国庆假期倒计时程序

    想了解基于python写个国庆假期倒计时程序的相关内容吗易小侠在本文为您仔细讲解python倒计时的相关知识和一些Code实例欢迎阅读和指正我们先划重点:python倒计时,python国庆假期倒计时,python假期倒计时下面大家一起来学习吧。..

网友评论

Copyright 2020 www.Shellfishsoft.com 【贝软下载站】 版权所有 软件发布

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 点此查看联系方式