7.1 创建接口、映射文件和测试类

++++++++++++++++++++++++++分割线++++++++++++++++++++++++++

注意namespace属性值为对应接口的全限定类名

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.rain.mybatis.mapper.SpecialSQLMapper"> </mapper>

++++++++++++++++++++++++++分割线++++++++++++++++++++++++++

7.2、模糊查询

7.2.1、接口方法

List<User> getUserByLike(@Param("mohu") String mohu);

7.2.2、测试方法

    @Test
public void testGetUserByLike(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession();
SpecialSQLMapper specialSQLMapper = sqlSession.getMapper(SpecialSQLMapper.class);
List<User> users = specialSQLMapper.getUserByLike("a");
for (User user : users) {
System.out.println(user);
}
}

7.2.3、映射文件

7.2.3.1、字符串拼接

    <!--List<User> getUserByLike(@Param("mohu") String mohu);-->
<select id="getUserByLike" resultType="User">
select * from t_user where username like '%${mohu}%'
</select>

7.2.3.2、函数处理

注意:各种数据库的字符串拼接函数会不相同,本示例用的是Mysql的字符串拼接函数

    <!--List<User> getUserByLike(@Param("mohu") String mohu);-->
<select id="getUserByLike" resultType="User">
select * from t_user where username like concat('%',#{mohu},"%")
</select>

7.2.3.3、双引号拼接

注意:这种方式最常用;因为既没有SQL注入的问题,也没有不同数据库函数不一致问题

    <!--List<User> getUserByLike(@Param("mohu") String mohu);-->
<select id="getUserByLike" resultType="User">
select * from t_user where username like "%"#{mohu}"%"
</select>

7.3、批量删除

7.3.1、接口方法

void deleteMoreUser(@Param("ids") String ids);

7.3.2、测试方法

    @Test
public void testDeleteMoreUser(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession();
SpecialSQLMapper specialSQLMapper = sqlSession.getMapper(SpecialSQLMapper.class);
specialSQLMapper.deleteMoreUser("7,8");
sqlSession.close();
}

7.3.3、映射文件

注意:这里使用#{}占位符赋值会报错,因为ids是字符串,占位符赋值会自动为其添加单引号,而id字段是数值类型;

除了使用${}字符串拼接之外,批量删除还可以用Mybatis的动态SQL功能

    <!--void deleteMoreUser(@Param("ids") String ids);-->
<delete id="deleteMoreUser">
delete from t_user where id in (${ids})
</delete>

7.3.4、执行效果

+++++++++++++++++++++++++++++++++分割线+++++++++++++++++++++++++++++++++

+++++++++++++++++++++++++++++++++分割线+++++++++++++++++++++++++++++++++

7.4、动态设置表名

7.4.1、接口方法

List<Map<String,Object>> getAllData(@Param("tableName") String tableName);

7.4.2、映射文件

注意:这里使用#{}占位符赋值会报错,因为表名不能有单引号

    <!--List<Map<String,Object>> getAllData(@Param("tableName") String tableName);-->
<select id="getAllData" resultType="Map">
select * from ${tableName}
</select>

7.4.3、测试方法

    @Test
public void testGetAllData(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession();
SpecialSQLMapper specialSQLMapper = sqlSession.getMapper(SpecialSQLMapper.class);
List<Map<String, Object>> t_user = specialSQLMapper.getAllData("t_user");
for (Map<String, Object> map : t_user) {
System.out.println(map);
}
sqlSession.close();
}

7.4.4、执行效果

7.5、添加功能获取自增主键

7.5.1、接口方法

注意:当参数是实体类时,不需要使用@Param注解,因为可以通过实体类的属性名来获取参数值

void insertUser(User user);

7.5.2、映射文件

注意:因为增删改的返回值是存放受影响的行数的,所以获取的自增主键只能存放在实体类的某个属性中

    <!--void insertUser(User user);-->
<!--
useGeneratedKeys属性:设置当前的添加功能使用自增主键
keyProperty属性:设置获取的自增主键放在实体类的哪个属性中
-->
<insert id="insertUser" useGeneratedKeys="true" keyProperty="id">
insert into t_user values (null ,#{username},#{password},#{age},#{gender},#{email})
</insert>

7.5.3、测试方法

    @Test
public void testInsertUser(){
SqlSession sqlSession = SqlSessionUtils.getSqlSession();
SpecialSQLMapper specialSQLMapper = sqlSession.getMapper(SpecialSQLMapper.class);
User user = new User();
user.setUsername("111");
user.setPassword("111");
user.setEmail("111@11.com");
user.setGender("1");
user.setAge(11);
System.out.println(user);
specialSQLMapper.insertUser(user);
System.out.println(user);
sqlSession.close();
}

7.5.4、执行效果

注意执行添加功能后,id值的变化

7、Mybatis之特殊SQL的更多相关文章

  1. MyBatis的动态SQL详解

    MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑,本文详解mybatis的动态sql,需要的朋友可以参考下 MyBatis 的一个强大的特性之一通常是它 ...

  2. Mybatis解析动态sql原理分析

    前言 废话不多说,直接进入文章. 我们在使用mybatis的时候,会在xml中编写sql语句. 比如这段动态sql代码: <update id="update" parame ...

  3. Mybatis学习记录(五)----Mybatis的动态SQL

    1.  什么是动态sql mybatis核心 对sql语句进行灵活操作,通过表达式进行判断,对sql进行灵活拼接.组装. 1.1 需求 用户信息综合查询列表和用户信息查询列表总数这两个statemen ...

  4. 详解Java的MyBatis框架中SQL语句映射部分的编写

    这篇文章主要介绍了Java的MyBatis框架中SQL语句映射部分的编写,文中分为resultMap和增删查改实现两个部分来讲解,需要的朋友可以参考下 1.resultMap SQL 映射XML 文件 ...

  5. mybatis 使用动态SQL

    RoleMapper.java public interface RoleMapper { public void add(Role role); public void update(Role ro ...

  6. MyBatis框架——动态SQL、缓存机制、逆向工程

    MyBatis框架--动态SQL.缓存机制.逆向工程 一.Dynamic SQL 为什么需要动态SQL?有时候需要根据实际传入的参数来动态的拼接SQL语句.最常用的就是:where和if标签 1.参考 ...

  7. 使用Mybatis实现动态SQL(一)

    使用Mybatis实现动态SQL 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 写在前面:        *本章节适合有Mybatis基础者观看* 前置讲解 我现在写一个查询全部的 ...

  8. MyBatis探究-----动态SQL详解

    1.if标签 接口中方法:public List<Employee> getEmpsByEmpProperties(Employee employee); XML中:where 1=1必不 ...

  9. mybatis 的sql语句及使用mybatis的动态sql mybatis防注入

    由于看到写的比较详细的文档这里将之前的删掉了,只留下一些我认为能帮助理解的和关于动态sql及防注入的一些理解.文档链接  :mybatis官方文档介绍 <!-- 根据条件查询用户 --> ...

  10. java web(七): mybatis的动态sql和mybatis generator自动生成pojo类和映射文件

    前言: MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其它类似框架的经验,你就能体会到根据 不同条件拼接 SQL 语句的痛苦.例如拼接时要确保不能忘记添加必要的空格,还 ...

随机推荐

  1. Python-3.10手动配置环境变量

  2. 解决:django.db.utils.OperationalError: no such table: auth_user

    解决:django.db.utils.OperationalError: no such table: auth_user 我们在创建Django项目的时候已经创建这个表了,表一般都保存在轻量级数据库 ...

  3. Create Vite App 支持 OpenTiny 啦🎉

    大家好,我是 Kagol,个人公众号:前端开源星球. 一个月前,日日自新写了一篇介绍 Create Vite App 开源项目的文章: 基于vite 4.x 快速搭建开箱即用,高度可定制化模版脚手架 ...

  4. 如何通过Java代码将 PDF文档转为 HTML格式

    虽然PDF文件适合用于打印和发布,但不适合所有类型的文档.例如,包含复杂图表和图形的文档可能无法在PDF中呈现得很好.但是HTML文件可以在任何可运行浏览器的计算机上进行阅读并显示.并且HTML还具有 ...

  5. 代码随想录算法训练营Day16二叉树|104.二叉树的最大深度 559.n叉树的最大深度 111.二叉树的最小深度  222.完全二叉树的节点个数

    代码随想录算法训练营 代码随想录算法训练营Day16二叉树|104.二叉树的最大深度 559.n叉树的最大深度 111.二叉树的最小深度  222.完全二叉树的节点个数 104.二叉树的最大深度 题目 ...

  6. Netty实战(五)

    一.什么是ByteBuf 我们前面说过,网络数据的基本单位总是字节.Java NIO 提供了 ByteBuffer 作为它的字节容器,但是这个类使用起来过于复杂,而且也有些繁琐.ByteBuffer ...

  7. 【一步步开发AI运动小程序】十一、人体关键点跳跃追踪

    随着人工智能技术的不断发展,阿里体育等IT大厂,推出的"乐动力"."天天跳绳"AI运动APP,让云上运动会.线上运动会.健身打卡.AI体育指导等概念空前火热.那 ...

  8. GTX.Zip:一款可以替代 gzip 的基因大数据压缩软件

    今天给大家推荐一款基因大数据压缩的大杀器:GTX.Zip. GTX.Zip 这款软件是由曾在 2016 年 GCTA 风云挑战赛中的那匹黑马--人和未来生物科技有限公司开发的,而当时他们也是打破了基因 ...

  9. k8s实战案例之部署Zookeeper集群

    1.Zookeeper简介 zookeeper是一个开源的分布式协调服务,由知名互联网公司Yahoo创建,它是Chubby的开源实现:换句话讲,zookeeper是一个典型的分布式数据一致性解决方案, ...

  10. 你以为搞个流水线每天跑,团队就在使用CI/CD实践了?

    在实践中,很多团队对于DevOps 流水线没有很透彻的理解,要不就创建一大堆流水线,要不就一个流水线通吃.实际上,流水线的设计和写代码一样,需要基于"业务场景"进行一定的设计编排, ...