**
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}
[]
至此我们通过注解的方式实现了多表查询。