mybatis 模糊查询的实现方法

 更新时间:2017年10月30日 10:10:52   作者:CSDN_LQR  
这篇文章主要介绍了mybatis 模糊查询的实现方法的相关资料,希望通过本文能帮助到大家,让大家掌握这部分内容,需要的朋友可以参考下

mybatis 模糊查询的实现方法

mybatis的逆向助手确实好用,可以省去很多编写常规sql语句的时间,但是它没办法自动生成模糊查询语句,但开发中模糊查询是必不可少的,所以,需要手动对mapper编写模糊查询功能。

这里先明确MyBatis/Ibatis中#和$的区别:

1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号。如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by “111”, 如果传入的值是id,则解析成的sql为order by “id”.

2. $将传入的数据直接显示生成在sql中。如:order by $user_id$,如果传入的值是111,那么解析成sql时的值为order by user_id, 如果传入的值是id,则解析成的sql为order by id.

3. #方式能够很大程度防止sql注入。

4. $方式无法防止Sql注入。

5. $方式一般用于传入数据库对象,例如传入表名.

6. 一般能用#的就别用$.

ps:在使用mybatis中还遇到<![CDATA[]]>的用法,在该符号内的语句,将不会被当成字符串来处理,而是直接当成sql语句,比如要执行一个存储过程。

我们的需求是对一个User进行模糊查询,思路是对所有基本字段(username,gender等)都跟传入的key(关键字)进行比较。

1、对UserMapper.xml编码

 <select id="queryUserByKey" parameterType="string"
    resultType="com.lqr.pojo.User">
    select * from user where uid like CONCAT('%',#{key},'%')
    or username like CONCAT('%',#{key},'%')
    or realname like CONCAT('%',#{key},'%')
    or identification like CONCAT('%',#{key},'%')
    or email like CONCAT('%',#{key},'%')
  </select>

2、对UserMapper.java编码

List<User> queryUserByKey(String key);

以上是本人在开发中遇到的情景,往后有其他mybatis模糊查询的使用再继续记录。

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • 详解MySQL中的分组查询与连接查询语句

    详解MySQL中的分组查询与连接查询语句

    这篇文章主要介绍了MySQL中的分组查询与连接查询语句,同时还介绍了一些统计函数的用法,需要的朋友可以参考下
    2016-03-03
  • mysql常用函数之group_concat()、group by、count()、case when then的使用

    mysql常用函数之group_concat()、group by、count()、case whe

    本文主要介绍了mysql常用函数之group_concat()、group by、count()、case when then的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • mysql死锁和分库分表问题详解

    mysql死锁和分库分表问题详解

    这篇文章主要给大家介绍了关于mysql死锁和分库分表问题的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • 虚拟主机中phpMyAdmin的安装配置方法

    虚拟主机中phpMyAdmin的安装配置方法

    phpMyAdmin 是一套可以通过WEB来管理 MySQL-server 以及单一数据库的 PHP 程序。对于一些虚拟空间的站点来说,应该是不可缺少的吧!!!
    2010-06-06
  • MySQL截取和拆分字符串函数用法示例

    MySQL截取和拆分字符串函数用法示例

    这篇文章主要介绍了MySQL截取和拆分字符串函数用法,结合实例形式分析了mysql针对字符串的截取与拆分函数SUBSTRING及SUBSTRING_INDEX相关使用方法,需要的朋友可以参考下
    2016-09-09
  • MySQL中json_extract函数说明及使用方式

    MySQL中json_extract函数说明及使用方式

    今天看mysql中的json数据类型,涉及到一些使用,使用到了函数json_extract来,下面这篇文章主要给大家介绍了关于MySQL中json_extract函数说明及使用方式的相关资料,需要的朋友可以参考下
    2022-08-08
  • Mysql中order by、group by、having的区别深入分析

    Mysql中order by、group by、having的区别深入分析

    本篇文章是对Mysql中order by、group by、having的区别进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • MySQL对数据库和表进行DDL命令的操作代码

    MySQL对数据库和表进行DDL命令的操作代码

    DDL(Data Definition Language),是数据定义语言的缩写,它是SQL(Structured Query Language)语言的一个子集,用于定义或修改数据库的结构,本文给大家介绍了MySQL对数据库和表进行DDL命令的操作,需要的朋友可以参考下
    2024-07-07
  • 在Ubuntu或Debian系统的服务器上卸载MySQL的方法

    在Ubuntu或Debian系统的服务器上卸载MySQL的方法

    这篇文章主要介绍了在Ubuntu或Debian系统的服务器上卸载MySQL的方法,适用于Debian系的Linux系统,需要的朋友可以参考下
    2015-06-06
  • MySQL5.6主从复制(mysql数据同步配置)

    MySQL5.6主从复制(mysql数据同步配置)

    这篇文章主要介绍了MySQL5.6主从复制也就是mysql数据同步配置方法,需要的朋友可以参考下
    2016-11-11

最新评论