SpringBoot整合Mybatis之各种查询、模糊查询、批量删除、动态表名操作

目录
  • 一、普通查询
    • 1. 若查询出的数据只有一条
    • 2. 若查询出的数据有多条
  • 二、模糊查询 like "%"#{name}"%"
  • 三、批量删除 in (${ids})

一、普通查询

1. 若查询出的数据只有一条

a>可以通过实体类对象接收

    <!-- Dish getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="com.athorse.entities.Dish">
        select * from dish where name = #{name}
    </select>

b>可以通过list集合接收

<!-- List<Dish> getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="com.athorse.entities.Dish">
        select * from dish where name = #{name}
    </select>

c>可以通过map集合接收

<!-- Map<String,Object> getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="map">
        select * from dish where name = #{name}
    </select>

2. 若查询出的数据有多条

a> 可以通过list集合接收

<!-- List<Dish> getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="com.athorse.entities.Dish">
        select * from dish where name = #{name}
    </select>

b>可以通过map类型的list集合接收

<!-- List<Map<String,Object>> getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="map">
        select * from dish where name = #{name}
    </select>

c>可以在mapper接口的方法上添加@MapKey注解,此时就可以将每条数据转换的map集合作为值,以某个字段的值作为键。

二、模糊查询 like "%"#{name}"%"

<!-- List<Dish> getDishByName(@Param("name") String name);-->
 <select id="getDishByName" resultType="com.athorse.entities.Dish">
        select * from dish where name like "%"#{name}"%"
 </select>

三、批量删除 in (${ids})

<!--Integer deleteMore(@Param("ids") String ids);-->
    <delete id="deleteMore">
        delete from dish where id in (${ids})
    </delete>

四、动态设置表名 ${tableName}

<!-- List<Dish> getDishs(@Param("tableName") String tableName);-->
    <select id="getDishs" resultType="com.athorse.entities.Dish">
        select * from ${tableName}
    </select>

总结:#{}会自动的拼接上'',而${}不会,所以特殊场景下需要使用${}

到此这篇关于SpringBoot整合Mybatis之各种查询、模糊查询、批量删除、动态表名的文章就介绍到这了,更多相关SpringBoot整合Mybatis查询内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • SpringBoot整合mybatis-generator插件流程详细讲解

    mybatis-generator 插件 mybatis 相关依赖 <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>3.0.1</version> </dependency> <dependency> <gr

  • IDEA创建SpringBoot项目整合mybatis时mysql-connector-java报错异常的详细分析

    目录 报错如图: 解决方式一: 解决方式二: 总结 For artifact {com.mysql:mysql-connector-j:null:jar}: The version cannot be empty.报错异常分析: 报错如图: 在pom.xml文件中 会是报红状态,我一直以为是导入不完全,是mysql-connector-java没有写全,所以一直解决不了,最后发现mysql-connector-java自8.0.31后更名为mysql-connector-j了. 现在分析一下它给

  • 手把手教你SpringBoot整合Mybatis

    目录 Mybatis的简单介绍 1 环境搭建 2 整合方式一:注解版 2.1 配置 2.2 编码 2.3 测试 3 整合方式二:XML版 3.1 配置 3.2 编码 3.3 测试 4 总结 Mybatis的简单介绍 ​ MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis .2013年11月迁移到Github. ​ iBATIS一词来源于“internet”

  • SpringBoot整合TKMyBatis实现单表增删改查操作

    目录 什么是TKMybatis SpringBoot整合TKMybatis 实体类注解 TKMapper接口如何使用 基本增删改操作 批量查询和删除 批量添加 自定义查询条件Example Example 条件设置 Example 使用 什么是TKMybatis TKMybatis 是基于Mybatis 框架开发的一个工具,内部实现了对单表的基本数据操作,只需要简单继承 TKMybatis 提供的接口,就能够实现无需编写任何 sql 即能完成单表操作. SpringBoot整合TKMybatis

  • SpringBoot整合Mybatis与MybatisPlus方法详细讲解

    目录 一.整合MyBatis操作 1.配置模式 2.注解模式 3.混合模式 二.整合 MyBatis-Plus 完成CRUD 1.什么是MyBatis-Plus 2.整合MyBatis-Plus 3.CRUD功能 一.整合MyBatis操作 官网:MyBatis · GitHub SpringBoot官方的Starter:spring-boot-starter-* 第三方的starter的格式: *-spring-boot-starter <dependency> <groupId>

  • springboot整合mybatis实现多表查询的实战记录

    目录 什么是mybatis 1.一对一查询(例一个用户一个账户) 1.1.实体类 1.2.数据库表 1.3.持久层接口 2.一对多查询(例一个用户对应多个账户) 2.1.实体类 2.2.数据库表 2.3.持久层接口 3.总结 4.多对多的查询(例一个用户多个角色) 4.1.实体类 4.2.数据库表 4.3.持久层接口 5.多对一(一个用户对应多个老师) 5.1 实体类 5.2.数据库表 5.3.持久层接口 总结 什么是mybatis (1)Mybatis 是一个半 ORM(对象关系映射)框架,它

  • springboot整合mybatis实现简单的一对多级联查询功能

    本文的目的是用springboot整合mybatis实现一个简单的一对多查询.(查询一个用户有多少件衣服) 第一步:数据库中,可以直接在navicat中建立两张我们需要用到的表 users DROP TABLE IF EXISTS `users`; CREATE TABLE `users` ( `id` int(0) NOT NULL AUTO_INCREMENT, `name` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_

  • Mybatis中的like模糊查询功能

    1.  参数中直接加入%% param.setUsername("%CD%"); param.setPassword("%11%"); <select id="selectPersons" resultType="person" parameterType="person"> select id,sex,age,username,password from person where true &

  • springboot使用JPA时间类型进行模糊查询的方法

    这个问题是我自己开发中遇到的问题  数据库使用的是mysql5.6  字段名称为checkingTime  类型为timestamp 显而易见 存到库中的是保留6位毫秒 即yyyy-MM-dd HH:mm:ss.ssssss  此时需求是精确到分钟的相同时间 不进行存储 这时候就需要进行模糊查询   搜了一圈百度 并没有什么好用的方法 我的bean类定义的是date类型 使用注解将类型更改为timestamp 存入库中 其实在做模糊查询的时候  只需要向持久层传入String类型参数即可 我的做

  • MyBatis使用Map与模糊查询的方法示例

    当我们的实体类.或者数据库里的表.字段或者参数很多,这个时候考虑使用map 一.使用map传参插入数据 1.编写Dao接口/Mapper层 使用Map做参数 //Dao接口/Mapper层 使用Map传参 int addUser2(Map<String,Object> map); 2.编写Mapper.xml中的sql语句 <!-- 传递map的key--> <insert id="addUser2" parameterType="map&quo

  • springboot使用mybatis一对多的关联查询问题记录

    springboot使用mybatis一对多的关联查询 由于刚开始写java不久,对sql语句的熟悉度还是不够熟练,虽然现在使用的mybatisPlus比较多,但我始终觉得sql不能忘也不能不用,刚好最近有个需求需要做到关联的查询,时间也算充足,所以用sql来写,于是踩了很久坑,终于跳出来了,小小记录一下. 一对多 # 我这里是一对多查询,一张主表两张副表,最后还要有一张VO表(就是做关联映射用的),主表和副表的实体我就不贴了,以下是VO实体 这是我的controller @RequestMap

  • mybatis Example Criteria like 模糊查询问题

    目录 简介 Criteria类 简单实例 生成简单的WHERE子句 复杂查询 模糊查询实战 总结 用Mybatis代码生成工具会产生很多个XXXExample类,这些类的作用是什么? 查阅了很多资料,在这里总结归纳一下 简介 XXXExample类用于构造复杂的筛选条件 它包含一个名为Criteria的内部静态类,它包含将在where子句中一起结合的条件列表. Criteria类的集合允许您生成几乎无限类型的where子句. 可以使用createCriteria方法或or方法创建Criteria

  • Springboot整合Mybatis传值的常用方式总结

    方式一:直接传 接口 public interface UserMapper { public List<User> getUserById(int id); } xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.or

  • SpringBoot整合MyBatis逆向工程及 MyBatis通用Mapper实例详解

    一.添加所需依赖,当前完整的pom文件如下: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd&q

  • SpringBoot整合Mybatis实现CRUD

    准备工具:IDEA jdk1.8 Navicat for MySQL Postman 一.新建Project 选择依赖:mybatis Web Mysql JDBC 项目结构 pom依赖: <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.o

随机推荐