MyBatis中的mapper.xml配置教程

 更新时间:2024年01月02日 14:35:53   作者:象鼻山大王  
这篇文章主要介绍了MyBatis中的mapper.xml配置,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

 1、配置获取添加对象的ID

<!--    配置我们的添加方法,获取到新增加了一个monster对象的id
        useGeneratedKeys="true" 意思是需要获取新加对象的主键值
        keyProperty="monster_id" 表示将获取到的id值赋值给Monster对象的monster_id属性
-->
    <insert id="addMonster" parameterType="Monster"
    useGeneratedKeys="true" keyProperty="monster_id">
        INSERT INTO mybatis_monster_ (monster_id,age,birthday,email,gender,name,salary)
        VALUES (#{monster_id},#{age},#{birthday},#{email},#{gender},#{name},#{salary})
    </insert>
  @Test
    public void testAdd() {
        Monster monster = new Monster();
        for(int i=10;i<20;i++) {
            monster.setAge(100+i);
            monster.setBirthday(new Date());
            monster.setEmail("123@qq.com");
            monster.setGender(1);
            monster.setSalary(8928.00);
            monster.setName("银角"+i);
            monsterMapper.addMonster(monster);
            System.out.println("获取添加的对象id" + monster.getMonster_id());
        }
    }

2.parameterType(输入参数类型)的再说明

(1)传入简单类型,比如按照id查Person   (单条件查询)

(2)传入POJQ类型,查询时需要有多个筛选条件(将多个条件封装到pojo中,将pojo作为参数传入)

比如 请查询monster_id =1或者 name='白骨精'的妖怪.

注意:当有多个条件时,传入的参数就是Pojo类型的Java对象,比如这里的Monster对象,

2.1如何模糊查询

        当我们传入的是String时,可以使用 ${}接收参数

首先,在MonsterMapper中,写这个方法, 查询名字当中含有“狐狸精”的妖怪

public Monster findByName(String name);

然后,映射文件中写这个语句,注意${name}

<select id="findByName" resultType="com.bin.mybatis.entity.Monster" parameterType="String">
       SELECT * FROM mybatis_monster_
       WHERE name like '%${name}%'
   </select>

3、实现参数是HashMap

        我们可以使用HashMap来实现多条件的查询

 
//    查询id>10而且salary大于40的所有妖怪
    public List<Monster> findMonsterByIdAndSalary(Map<String,Object> map);
    <select id="findMonsterByIdAndSalary" resultType="com.bin.mybatis.entity.Monster" parameterType="Map">
        SELECT * FROM mybatis_monster_
        WHERE monster_id>#{monster_id} AND salary>#{salary}
    </select>
  @Test
    public void findMonsterByIdAndSalary(){
        Map<String, Object> map = new HashMap<String,Object>();
        map.put("monster_id", 6);
        map.put("salary", 1234);
        List<Monster> monsterList = monsterMapper.findMonsterByIdAndSalary(map);
        for (Monster monster : monsterList) {
            System.out.println(monster);
        }
    }

4、返回参数是map

 //    查询id>10而且salary大于40的所有妖怪
    //  第二种写法:参数和返回类型都是Map
    public Map<String,Object> findMonsterByIdAndSalary2(Map<String,Object> map);
  <select id="findMonsterByIdAndSalary2" resultType="Map" parameterType="Map">
        SELECT * FROM mybatis_monster_
        WHERE monster_id>#{monster_id} AND salary>#{salary}
    </select>
 
    @Test
    public void findMonsterByIdAndSalary(){
        Map<String, Object> map = new HashMap<String,Object>();
        map.put("monster_id", 6);
        map.put("salary", 1234);
        List<Monster> monsterList = monsterMapper.findMonsterByIdAndSalary(map);
        for (Monster monster : monsterList) {
            System.out.println(monster);
        }
    }

到此这篇关于MyBatis中的mapper.xml配置的文章就介绍到这了,更多相关MyBatis mapper.xml配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java遍历HashMap简单的方法

    java遍历HashMap简单的方法

    这篇文章主要介绍了java遍历HashMap简单的方法,以实例形式简单分析了采用java遍历HashMap的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • 使用注解解决ShardingJdbc不支持复杂SQL方法

    使用注解解决ShardingJdbc不支持复杂SQL方法

    这篇文章主要为大家介绍了使用注解解决ShardingJdbc不支持复杂SQL方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • 解决Mybatis-plus和pagehelper依赖冲突的方法示例

    解决Mybatis-plus和pagehelper依赖冲突的方法示例

    这篇文章主要介绍了解决Mybatis-plus和pagehelper依赖冲突的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • SpringBoot集成Druid监控慢SQL的详细过程

    SpringBoot集成Druid监控慢SQL的详细过程

    数据库连接池是一个至关重要的组成部分,一个优秀的数据库连接池可以显著提高应用程序的性能和可伸缩性,常见的连接池:Druid、HikariCP、C3P0、DBCP等等,本文将详细介绍如何在Spring Boot项目中配置数据源,集成Druid连接池,以实现更高效的数据库连接管理
    2024-06-06
  • java微信开发API第三步 微信获取以及保存接口调用凭证

    java微信开发API第三步 微信获取以及保存接口调用凭证

    这篇文章主要为大家详细介绍了java微信开发API第二步,微信获取以及保存接口调用凭证,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • BaseMapper接口的使用方法

    BaseMapper接口的使用方法

    这篇文章主要介绍了BaseMapper接口的使用方法,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-12-12
  • SpringBoot管理RabbitMQ中的Channel详解

    SpringBoot管理RabbitMQ中的Channel详解

    这篇文章主要介绍了SpringBoot管理RabbitMQ中的Channel详解,channel仅存在于connection的上下文中,而不会单独存在,当channel关闭时,其上的所有channel也会关闭,需要的朋友可以参考下
    2023-08-08
  • 使用 mybatis 自定义日期类型转换器的示例代码

    使用 mybatis 自定义日期类型转换器的示例代码

    这篇文章主要介绍了使用 mybatis 自定义日期类型转换器的示例代码,这里使用mybatis中的typeHandlers 实现的,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-03-03
  • Java中的包装类是什么

    Java中的包装类是什么

    这篇文章主要介绍了Java中的包装类是什么,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • Java过滤器doFilter里chain.doFilter()函数的理解

    Java过滤器doFilter里chain.doFilter()函数的理解

    这篇文章主要介绍了Java过滤器doFilter里chain.doFilter()函数的理解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11

最新评论