MyBatis 动态绑定接口

MyBatis动态绑定接口

提供接口

首先, 在mapper包下提供相应的接口

package pers.jssd.mapper;

import pers.jssd.pojo.User;

import java.util.List;

/**
 * @author jssdjing@gmail.com
 */
public interface UserMapper {
    List<User> selAll();
}

提供和接口相互绑定的xml文件

此处注意, 命名空间必须是绑定的接口的全限定路径, 不能更改. id必须和绑定的接口中方法相同

<?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="pers.jssd.mapper.UserMapper">
    <select id="selAll" resultType="User">
        select *
        from myuser
    </select>
</mapper>

测试方法

@Test
public void selectAll() {
    SqlSession session = MyBatisUtil.getSession();

    UserMapper mapper = session.getMapper(UserMapper.class);
    List<User> users = mapper.selAll();
    for (User user : users) {
        System.out.println("user = " + user);
    }

    session.close();
}

多参数解决方案

索引传递方法

在mapper中的接口如果是这样定义的

/**
     * 通过id和name查询对象
     *
     * @param id   用户id
     * @param name 用户姓名
     * @return 返回查找到的User对象
     */
User selByIdName(int id, String name);

在Mapper中配置参数的时候, 不配置ParameType类型. 取的参数的时候, 用索引方式取得传递的参数

<select id="selByIdName" resultType="User">
    select * from myuser where id = #{0} and name = #{1}
</select>

测试方法:

@Test
public void testParams() {
    SqlSession session = MyBatisUtil.getSession();

    UserMapper mapper = session.getMapper(UserMapper.class);
    User user = mapper.selByIdName(1002, "seo");
    System.out.println("user = " + user);

    session.close();
}

注解方法

在接口中取得参数的时候, 加上注解

/**
     * 通过id和name查询对象
     *
     * @param id   用户id
     * @param name 用户姓名
     * @return 返回查找到的User对象
     */
User selByIdName(@Param("id") int id, @Param("name") String name);

对应的xml中, 就可以用注解配置的别名取得参数. 事实上, MyBatis内部将注解和参数封装成了一个map进行传递了进去

<select id="selByIdName" resultType="User">
    select * from myuser where id = #{id} and name = #{name}
</select>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值