Mybatis中使用万能的Map传参实现

在编程中,有可能遇到我们的实体类或者数据库中表的字段或参数过多的情况,那这时候用Map传参是比较理想的选择。

Map的特性是键值对应的,只要确定了一个键key,那么值value可以是任何的数据,这样就可以在map内存中存入任何数据。

下面例子演示在mybatis中结合Map实现基本的增删改查

数据库表(fruits)结构:

实体类:

package com.pojo.pp1;

import java.math.BigDecimal;

/**
 * 简述:
 *创建实体
 * @author:LiYansheng
 * @date:2021/07/20 22:29
 * @version:
 */
public class fruits {
    private int id;
    private String name;
    private BigDecimal price;

    public fruits(int id, String name, BigDecimal price) {
        this.id = id;
        this.name = name;
        this.price = price;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public BigDecimal getPrice() {
        return price;
    }

    public void setPrice(BigDecimal price) {
        this.price = price;
    }

    @Override
    public String toString() {
        return "fruits{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", price=" + price +
                '}';
    }
}

Dao接口:

package com.pojo.Dao;

import com.pojo.pp1.fruits;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;
/**
 * 简述:
 *
 * @author:LiYansheng
 * @date:2021/07/20 22:31
 * @version:
 */
public interface fruitsDao {
    /*查询全部信息*/
    List<fruits> getfruitsList();

    /*通过ID查询信息*/
    fruits getfruitsById(@Param("map") Map<String, Object> map);

    /*添加信息*/
    int addfruits(@Param("map") Map<String, Object> map);

    /*删除信息*/
    int deletefruits(@Param("map") Map<String, Object> map);

    /*修改信息*/
    int updatefruits(@Param("map") Map<String, Object> map);
}

Dao接口.XML文件:

<?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="com.pojo.Dao.fruitsDao">
    <select id="getfruitsList" resultType="fruits">
        select id,name,price from fruits
    </select>

    <select id="getfruitsById" parameterType="Map" resultType="fruits">
        select id,name,price from fruits where id=#{map.id};
    </select>

    <insert id="addfruits" parameterType="Map" >
        insert into fruits(id,name,price) values (#{map.id},#{map.name},#{map.price});
    </insert>

    <delete id="deletefruits" parameterType="Map" >
        delete from fruits where id=#{map.id};
    </delete>

    <update id="updatefruits" parameterType="Map" >
        update  fruits set name=#{map.name},price=#{map.price} where id=#{map.id}
    </update>
</mapper>

在Test类中测试运行:

package com.pojo.Dao;

import com.pojo.pp1.fruits;
import com.utils.mybatisUtils;

import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

import java.math.BigDecimal;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
 * 简述:
 *
 * @author:LiYansheng
 * @date:2021/07/20 22:39
 * @version:
 */
public class fruitsDaoTest {
    @Test
    public void getfruitsListTest() {
        SqlSession sqlSession = mybatisUtils.getSqlSession();
        fruitsDao fruitsDao = sqlSession.getMapper(com.pojo.Dao.fruitsDao.class);
        List<fruits> fruitsList = fruitsDao.getfruitsList();
        for (fruits f : fruitsList) {
            System.out.println(f);
        }
        sqlSession.close();
    }
    @Test
    public void getfruitsByIdTest() {
        SqlSession sqlSession = mybatisUtils.getSqlSession();
        fruitsDao fruitsDao = sqlSession.getMapper(com.pojo.Dao.fruitsDao.class);
        Map<String, Object> map = new HashMap<>();
        map.put("id", 3);
        fruits f = fruitsDao.getfruitsById(map);
        System.out.println(f);
        sqlSession.close();
    }
    @Test
    public void addfruits() {
        SqlSession sqlSession = mybatisUtils.getSqlSession();
        fruitsDao fruitsDao = sqlSession.getMapper(com.pojo.Dao.fruitsDao.class);
        Map<String, Object> map = new HashMap<>();
        map.put("id", 0);
        map.put("name", "watermelon");
        BigDecimal bigDecimal= BigDecimal.valueOf(2);
        map.put("price", bigDecimal);
        int a = fruitsDao.addfruits(map);
        if (a > 0) {
            System.out.println("添加信息ok");
        }
        sqlSession.commit();
        sqlSession.close();
    }
    @Test
    public void deletefruits() {
        SqlSession sqlSession = mybatisUtils.getSqlSession();
        fruitsDao fruitsDao = sqlSession.getMapper(com.pojo.Dao.fruitsDao.class);
        Map<String, Object> map = new HashMap<>();
        map.put("id", 3);
        int a = fruitsDao.deletefruits(map);
        if (a > 0) {
            System.out.println("删除信息ok");
        }
        sqlSession.commit();
        sqlSession.close();
    }
    @Test
    public void updatefruits() {
        SqlSession sqlSession = mybatisUtils.getSqlSession();
        fruitsDao fruitsDao = sqlSession.getMapper(com.pojo.Dao.fruitsDao.class);
        Map<String, Object> map = new HashMap<>();
        map.put("id", 1);
        BigDecimal bigDecimal = BigDecimal.valueOf(5);
        map.put("name", "Big_apple");
        map.put("price", bigDecimal);
        int a = fruitsDao.updatefruits(map);
        if (a > 0) {
            System.out.println("修改信息ok");
        }
        sqlSession.commit();
        sqlSession.close();
    }
}

测试结果,全部都可以通过

需要注意的地方:

标记序号的地方是两种写类型的方式

第二种方式需要在项目配置中resources下mybatis-config.xml的文件中加入以下的类型别名:

<typeAliases>
        <typeAlias type="java.util.Map" alias="Map"/>
</typeAliases>

推荐用第二种方式哦

到此这篇关于Mybatis中使用万能的Map传参实现的文章就介绍到这了,更多相关Mybatis Map传参内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • MyBatis查询返回Map示例代码

    前言 有时候我们做查询, 只需要返回两个string类型的字段,方便我们后续的处理.比如根据商品的code查询对应的分类的名字,需要返回一个map, key为商品code, value为商品分类对应的名称.以方便我们后续对结果集的处理.如果你直接用mybatis返回一个map, 你可能会发现,结果根据不是自己需要的.这时候我们需要自己实现一个ResultHandler来实现我们想要的结果,废话不多说,直接上代码 方法如下 第一步,在mapper.xml文件当中,定义一个ResultMap <re

  • MyBatis传入集合 list 数组 map参数的写法

    foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合.foreach元素的属性主要有item,index,collection,open,separator,close.item表示集合中每一个元素进行迭代时的别名,index指定一个名字,用于表示在迭代过程中,每次迭代到的位置,open表示该语句以什么开始,separator表示在每次进行迭代之间以什么符号作为分隔符,close表示以什么结束,在使用foreach的时候最关键的也是最容易出错的就是collection属性

  • Mybatis中注解@MapKey的使用详解

    mybatis的原身是ibatis,现在已经脱离了apache基金会,新官网是http://www.mybatis.org/. 在研究Mybatis源码之前并不知道这个注解的妙用的,但是当我看到参数解析的时候 有这个一个注解,所以我了解了一下,当我们返回像Map<String, Map<String, Object>>这种类型的时候,我们往往很难做到,因为这里面可能是多个表的数据,所以我们不可能再建一个模型. 这时候我们就可以使用这个注解了 @Retention(Retention

  • Mybatis增删改查mapper文件写法详解

      1. 插入 <mapper namespace="需要实现接口的全类名"> <insert id="需要实现的接口里的方法名" parameterType="方法参数类型,如果是对象要写全类名"> INSERT sql命令(命令里通过#{}获取对象属性) <!--注意属性名区分大小写 --> </insert> <mapper> EG: <mapper namespace=&q

  • MyBatis直接执行SQL的工具SqlMapper

    可能有些人也有过类似需求,一般都会选择使用其他的方式如Spring-JDBC等方式解决. 能否通过MyBatis实现这样的功能呢? 为了让通用Mapper更彻底的支持多表操作以及更灵活的操作,在2.2.0版本增加了一个可以直接执行SQL的新类SqlMapper. 我们来了解一下SqlMapper. SqlMapper提供的方法 SqlMapper提供了以下这些公共方法: Map<String,Object> selectOne(String sql) Map<String,Object&

  • Java的MyBatis框架中Mapper映射配置的使用及原理解析

    Mapper的内置方法 model层就是实体类,对应数据库的表.controller层是Servlet,主要是负责业务模块流程的控制,调用service接口的方法,在struts2就是Action.Service层主要做逻辑判断,Dao层是数据访问层,与数据库进行对接.至于Mapper是mybtis框架的映射用到,mapper映射文件在dao层用. 下面是介绍一下Mapper的内置方法: 1.countByExample ===>根据条件查询数量 int countByExample(UserE

  • 详解Mybatis通用Mapper介绍与使用

    使用Mybatis的开发者,大多数都会遇到一个问题,就是要写大量的SQL在xml文件中,除了特殊的业务逻辑SQL之外,还有大量结构类似的增删改查SQL.而且,当数据库表结构改动时,对应的所有SQL以及实体类都需要更改.这工作量和效率的影响或许就是区别增删改查程序员和真正程序员的屏障.这时,通用Mapper便应运而生-- 什么是通用Mapper 通用Mapper就是为了解决单表增删改查,基于Mybatis的插件.开发人员不需要编写SQL,不需要在DAO中增加方法,只要写好实体类,就能支持相应的增删

  • Mybatis-Plus BaseMapper的用法详解

    1.如何使用BaseMapper进行数据库的操作. 2.使用BaseMapper进行插入实体时如何让UUID的主键自动生成. Student实体类,其中id属性主键为UUID package com.huixiaoer.ant.api.model.bean; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableId; public class Stud

  • Mybatis中使用万能的Map传参实现

    在编程中,有可能遇到我们的实体类或者数据库中表的字段或参数过多的情况,那这时候用Map传参是比较理想的选择. Map的特性是键值对应的,只要确定了一个键key,那么值value可以是任何的数据,这样就可以在map内存中存入任何数据. 下面例子演示在mybatis中结合Map实现基本的增删改查 数据库表(fruits)结构: 实体类: package com.pojo.pp1; import java.math.BigDecimal; /** * 简述: *创建实体 * @author:LiYan

  • Java中数组的创建与传参方法(学习小结)

    (一)数组的创建 数组的创建包括两部分:数组的申明与分配内存空间. int score[]=null; //申明一维数组 score=new int[3]; //分配长度为3的空间 数组的申明还有另外一种方式: int[] score=null; //把中括号写在数组名前面 通常,在写代码时,为了方便,我们将两行合并为一行: int score[]=new int score[3]; //将数组申明与分配内存写在一行 (二)传递参数 由于初学java,这里只讨论值传递,不考虑地址传递.主要有3点

  • python中使用ctypes调用so传参设置遇到的问题及解决方法

    问题 近日在做一组声纹聚类时,使用了另一团队同学开发的声纹距离算法.该算法对外提供的是一组so包,需要使用方自己去使用.在python中调用纯so包一般使用ctypes类库,用起来看起来简单但也有不少细节容易犯错.本次使用过程中,就遇到传参的问题. 目标so库中对外export的函数是大致如下的三个函数: void* create_handler(); int extract_feature(void* hander); bool destroy(void* handler); 这三个函数使用起

  • Feign调用中的两种Header传参方式小结

    目录 Feign调用中的两种Header传参方式 在请求拦截器中统一配置 通过@RequestHeader注解 调用feign接口时,如何往header中添加参数 总结 Feign调用中的两种Header传参方式 在Spring Cloud Netflix栈中,各个微服务都是以HTTP接口的形式暴露自身服务的,因此在调用远程服务时就必须使用HTTP客户端. 我们可以使用JDK原生的URLConnection.Apache的Http Client.Netty的异步HTTP Client, Spri

  • Python中字符串的修改及传参详解

    发现问题 最近在面试的时候遇到一个题目,选择用JavaScript或者Python实现字符串反转,我选择了Python,然后写出了代码(错误的): #!/usr/bin/env python #-*-coding:utf-8-*- __author__ = 'ZhangHe' def reverse(s): l = 0 r = len(s) - 1 while l < r: s[l],s[r] = s[r],s[l] l += 1 r -= 1 return s 然后面试官问了两个问题: (1)

  • JavaScript中使用arguments获得函数传参个数实例

    JS与PHP在函数传参方面有点不同,PHP形参与实参个数要匹配,而JS就灵活多了,可以随意传参,实参比形参少或多都不会报错. 实参比形参多不会报错 function say(a){    alert(a); }   say('琼台博客','WEB技术博客'); 执行结果 我们再来看看形参比实参多的结果 function say(a,b){    alert('a 的值是 '+a+'\nb 的值是 '+b); }   say('琼台博客'); 执行结果 a 对应第一个实参"琼台博客",b

  • 通过字节码看java中this的隐式传参详解

    前言 从字节码看java中 this 隐式传参具体体现(和python中的self如出一辙,但是比python中藏得更深),也发现了 static 与 非 static 方法的区别所在! static与非static方法都是存储java的方法区.在static 方法中,没有this引用,因此无法使用当前类中所定义的变量,而非static方法则会默认传入this. 概述 this关键字,是一个隐式参数,另外一个隐式参数是super. this用于方法里面,用于方法外面无意义. this关键字一般用

  • 在python中实现导入一个需要传参的模块

    最近跑实验,遇到了一个问题: 由于实验数据集比较多,每次跑完一个数据集就需要手动更改文件路径,再将文件传到服务器,再运行实验,这样的话效率很低,必须要专门看着这个实验,啥时候跑完就手动修改运行下一个实验.我个人无法忍受这样低效率,就想能不能有什么解决的办法. 我们期望的解决办法是通过命令行传参来解决这个问题,因为接下来是需要编写shell脚本来批量运行实验,如果用输入语句的方式显得太笨拙. 在编写实验代码的时候,我将所有的参数集中到一个py文件中,这样便于后期的维护,现在的问题就是需要通过命令行

  • mybatis中的if test判断入参的值问题

    目录 mybatis if test判断入参的值 1.第一种判断方式 2.第二种判断方式 if test动态判断数字时出现的错误 mybatis中if test判断数字 mybatis if test判断入参的值 1.第一种判断方式 <if test=' requisition != null and requisition == "Y" '>    AND 表字段 = #{requisition} </if> 2.第二种判断方式 <if test=&qu

  • mybatis中返回多个map结果问题

    目录 mybatis返回多个map结果 mybatis返回map类型的注意事项及小技巧 1.resultType="java.util.Map" 2.定义一个resultMap标签, 3.返回的Map对象 mybatis返回多个map结果 如果返回一条结果,xml直接这样写: <select id="searchncomedateByInvestID" resultMap="java.util.HashMap">     select

随机推荐