【MyBatis】Mybatis 的parameterType 配置参数以及传递pojo包装对象进行查询

【MyBatis】Mybatis 的parameterType 配置参数以及传递pojo包装对象进行查询

parameterType 配置参数

在实现CRUD操作时,基本类型和String我们可以直接写类型名称, 也可以使用包名.类名的方式 , 例 如:java.lang.String。

实体类类型,目前我们只能使用全限定类名。
究其原因,是 mybaits 在加载时已经把常用的数据类型注册了别名,从而我们在使用时可以不写包名,而我们的是实体类并没有注册别名,所以必须写全限定类名。

在 mybatis 的官方文档的说明

这些都是支持的默认别名。我们也可以从源码角度来看它们分别都是如何定义出来的。
可以参考 TypeAliasRegistery.class 的源码。

传递 pojo 包装对象

开发中通过 pojo 传递查询条件 ,查询条件是综合的查询条件,不仅包括用户查询条件还包括其它的查询条件(比如将用户购买商品信息也作为查询条件),这时可以使用包装对象传递输入参数。
Pojo 类中包含 pojo。
需求:根据用户名查询用户信息,查询条件放到 QueryVo 的 user 属性中。

  • QueryVo
package com.siyi.domain;

public class QueryVo {

    public User user;

    public User getUser() {
        return user;
    }

    public void setUser(User user) {
        this.user = user;
    }
}
  • 持久层接口
package com.siyi.dao;

import com.siyi.domain.QueryVo;
import com.siyi.domain.User;

import java.util.List;

/**
 * 用户持久层接口
 */
public interface IUSerDao {
    /**
     * 根据queryVo中的条件查询用户
     * @param vo
     * @return
     */
    public List<User> findUserByVo(QueryVo vo);
}
  • 持久层接口的映射文件
<?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.siyi.dao.IUSerDao">
    <!-- 根据queryVo的条件查询用户 -->
    <select id="findUserByVo" parameterType="com.siyi.domain.QueryVo" resultType="com.siyi.domain.User">
        select * from user where username like #{user.username}
    </select>
</mapper>
  • 测试方法
    @Test
    public void testFindByVo(){
        QueryVo vo = new QueryVo();
        User user = new User();
        user.setUsername("%yi%");
        vo.setUser(user);
        List<User> users = iuSerDao.findUserByVo(vo);
        for (User u : users){
            System.out.println(u);
        }
    }
发布了476 篇原创文章 · 获赞 152 · 访问量 6万+

猜你喜欢

转载自blog.csdn.net/qq_41879343/article/details/104872073