Java日志三十二「Mybatis注解方式的多表查询」

**

Mybatis注解方式的多表查询

**
我们之前通过配置xml文件的方式可以实现多表查询,现在我们也可以通过注解的方式达到一样的效果。我们还是先来看项目文件结构:
在这里插入图片描述
与之前的xml方式多表查询很相似,只是少了UserDao.xml与AccountDao.xml两个配置文件。现在我们要通过注解的方式来实现之前的效果:

UserDao:

//开启二级缓存
@CacheNamespace(blocking = true)
public interface UserDao {

    /**
     * 查询所有用户
     * @return
     */
    @Select("select * from user")
    @Results(id ="userMap" ,value={
            @Result(id=true,column = "id",property = "userId"),
            @Result(column = "username",property = "userName"),
            @Result(column = "address",property = "userAddress"),
            @Result(column = "sex",property = "userSex"),
            @Result(column = "birthday",property = "userBirthday"),
            @Result(property = "accounts",column = "id",many = @Many(select = "Gao.Dao.AccountDao.findAccountByUid",fetchType = FetchType.LAZY))
    })
    List<User> findAll();

    @Select("select * from user where id=#{id}")
    @ResultMap("userMap")
    User findById(Integer id);

    /**
     * 根据姓名模糊查询
     * @param name
     * @return
     */
    @Select("select * from user where username like #{username}")
    @ResultMap(value = {"userMap"})
    //@ResultMap("userMap")
    List<User> findByName(String name);
}

AccountDao:

public interface AccountDao {
    /**
     * 查询所有账户,并且获取每个账户的用户信息
     * @return
     */
    @Select("select * from account")
    @Results(id = "accountMap",value = {
            @Result(id = true,column = "id",property = "id"),
            @Result(column = "uid",property = "uid"),
            @Result(column = "money",property = "money"),
            @Result(property = "user",column = "uid",one = @One(select="Gao.Dao.UserDao.findById",fetchType = FetchType.EAGER))
    })
    List<Account> findAll();

    /**
     * 根据用户id查询账户信息
     * @param uid
     * @return
     */
    @Select("select * from account where uid=#{uid}")
    List<Account> findAccountByUid(Integer uid);
}

这里解释一下新出现的注解,(建议大家与已经删掉的xml文件对比看,因为一个注解起到了某些标签的作用)


@Result注解
代替了id标签和result标签
@Result 中属性介绍:
id 是否是主键字段
column 数据库的列名 property 需要装配的属性名


@One注解(一对一) 代替了assocation标签,是多表查询的关键,在注解中用来指定子查询返回单一对象。
@One注解属性介绍:
select 指定用来多表查询的 sqlmapper
fetchType 会覆盖全局的配置参数 lazyLoadingEnabled。
使用格式:
@Result(column=" “,property=”",one=@One(select=""))


@Many注解(多对一)
代替了Collection标签,是是多表查询的关键,在注解中用来指定子查询返回对象集合。
属性与@One相似
使用格式:
@Result(property="",column="",many=@Many(select=""))


现在在测试方法中看一下查询所有用户与查询所有账户
账户查询:

@Test
    public void testFindAll(){
        List<Account> accounts=accountDao.findAll();
        for (Account account:accounts){
            System.out.println("------------------每个账户的信息------------------");
            System.out.println(account);
            System.out.println(account.getUser());
        }

结果

------------------每个账户的信息------------------
Account{id=1, uid=46, money=1000.0}
User{userId=46, userName='老王', userAddress='北京', userSex='男', userBirthday=Thu Mar 08 07:37:26 CST 2018}
------------------每个账户的信息------------------
Account{id=2, uid=45, money=1000.0}
User{userId=45, userName='update user clear cache', userAddress='山东省', userSex='男', userBirthday=Mon Mar 05 02:04:06 CST 2018}
------------------每个账户的信息------------------
Account{id=3, uid=48, money=2000.0}
User{userId=48, userName='小马宝莉', userAddress='北京修正', userSex='女', userBirthday=Fri Mar 09 01:44:00 CST 2018}

用户查询

@Test
    public void testFindAll(){
        List<User> users = userDao.findAll();
        for (User u:users){
            System.out.println("-------------每个用户的信息--------------");
            System.out.println(u);
            System.out.println(u.getAccounts());
        }
    }

结果

-------------每个用户的信息--------------
User{userId=41, userName='老王', userAddress='北京', userSex='男', userBirthday=Wed Feb 28 07:47:08 CST 2018}
[]
-------------每个用户的信息--------------
User{userId=42, userName='小二王', userAddress='北京金燕龙', userSex='女', userBirthday=Sat Mar 03 05:09:37 CST 2018}
[]
-------------每个用户的信息--------------
User{userId=45, userName='update user clear cache', userAddress='山东省', userSex='男', userBirthday=Mon Mar 05 02:04:06 CST 2018}
[Account{id=2, uid=45, money=1000.0}]
-------------每个用户的信息--------------
User{userId=46, userName='老王', userAddress='北京', userSex='男', userBirthday=Thu Mar 08 07:37:26 CST 2018}
[Account{id=1, uid=46, money=1000.0}]
-------------每个用户的信息--------------
User{userId=48, userName='小马宝莉', userAddress='北京修正', userSex='女', userBirthday=Fri Mar 09 01:44:00 CST 2018}
[Account{id=3, uid=48, money=2000.0}]
-------------每个用户的信息--------------
User{userId=50, userName='mybatis update user', userAddress='北京市顺义区', userSex='女', userBirthday=Wed Oct 14 19:34:00 CST 2020}
[]
-------------每个用户的信息--------------
User{userId=51, userName='AnnoTestSave', userAddress='邹平市', userSex='男', userBirthday=Tue Oct 20 19:36:38 CST 2020}
[]

至此我们通过注解的方式实现了多表查询。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值