Mybatis基于注解实现多表查询功能基于注解实现多表查询功能
主要介绍了Mybatis基于注解实现多表查询功能,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
对应的四种数据库表关系中存在四种关系:一对多,多对应,一对一,多对多。在前文中已经实现了xml配置方式实现表关系的查询,本文记录一下Mybatis怎么
通过注解实现多表的查询,算是一个知识的补充。
同样的先介绍一下Demo的情况:存在两个实体类用户类和账户类,用户类可能存在多个账户,即一对多的表关系。每个账户只能属于一个用户,即一对一或者多
对一关系。我们最后实现两个方法,第一个实现查询所有用户信息并同时查询出每个用户的账户信息,第二个实现查询所有的账户信息并且同时查询出其所属的用户
信息。
1.项目结构
2.领域类
public class Account implements Serializable{
private Integer id;
private Integer uid;
private double money;
private User user; //加入所属用户的属性
省略get 和set 方法.............................
}
public class User implements Serializable{
private Integer userId;
private String userName;
private Date userBirthday;
private String userSex;
private String userAddress;
private List<Account> accounts;
省略get 和set 方法.............................
}
在User中因为一个用户有多个账户所以添加Account的列表,在Account中因为一个账户只能属于一个User,所以添加User的对象。
3.Dao层
public interface AccountDao {
/**
*查询所有账户并同时查询出所属账户信息
*/
@Select("select * from account")
@Results(id = "accountMap",value = {
@Result(id = true,property = "id",column = "id"),
@Result(property = "uid",column = "uid"),
@Result(property = "money",column = "money"),
//配置用户查询的方式 column代表的传入的字段,一对一查询用one select 代表使用的方法的全限定名, fetchType表示查询的方式为立即加载还是懒加载
@Result(property = "user",column = "uid",one = @One(select = "com.example.dao.UserDao.findById",fetchType = FetchType.EAGER))
})
List<Account> findAll();
/**
* 根据用户ID查询所有账户
* @param id
* @return
*/
@Select("select * from account where uid = #{id}")
List<Account> findAccountByUid(Integer id);
}
public interface UserDao {
/**
评论0