博客
关于我
Mybatis_09多表查询之多对多
阅读量:770 次
发布时间:2019-03-21

本文共 4444 字,大约阅读时间需要 14 分钟。

MyBatis 多对多关系实践:用户与角色之间的映射关系

第一步:角色到用户的一对多关系

1. 引入

问题:查询角色获取角色下的用户信息。

实现:Role 到 User 多对多。

2. 编写实体类

创建 User 和 Role 实体类,实现多对多关系。每个 Role 可以关联多个 User,反之亦然。

public class Role implements Serializable {    private Integer roleId;    private String roleName;    private String roleDesc;    // Role 到 User 的映射关系    private List
users; public void setUsers(List
users) { this.users = users; } public List
getUsers() { return users; }}
public class User implements Serializable {    private Integer id;    private String username;    private Date birthday;    private String sex;    private String address;    // User 到 Role 的映射关系    private List
roles; public void setRoles(List
roles) { this.roles = roles; } public List
getRoles() { return roles; }}

3. 持久层接口

定义接口,表示数据库操作。

public interface IRoleDao {    // 查询所有 Role 角色    List
findRolelAll();}

4. MyBatis 配置文件

在 SqlMapConfig.xml 中配置 Role Dao。

5. 测试类

测试 Role 到 User 的映射关系。

public class RoleTest {    private InputStream in;    private SqlSessionFactory factory;    private SqlSession sqlSession;    private IRoleDao roleDao;    @Before    public void init() throws IOException {        in = Resources.getResourceAsStream("SqlMapConfig.xml");        factory = new SqlSessionFactoryBuilder().build(in);        sqlSession = factory.openSession(true);        roleDao = sqlSession.getMapper(IRoleDao.class);    }    @After    public void destory() throws Exception {        sqlSession.close();        in.close();    }    // 测试查询所有角色并获取用户信息    @Test    public void testFindRolelAll() {        List
roles = roleDao.findRolelAll(); for (Role role : roles) { System.out.println("这是一条记录:" + role); System.out.println("关联的用户:" + role.getUsers()); } }}

第二步:用户到角色的一对多关系

1. 引入

问题:查询用户获取角色信息。

实现:User 到 Role 多对多。


2. 编写实体类

创建 User 和 Role 实体类,实现多对多关系。反之亦然,用户可以关联多个角色。

public class User implements Serializable {    private Integer id;    private String username;    private Date birthday;    private String sex;    private String address;    // User 到 Role 的映射关系    private List
roles; public void setRoles(List
roles) { this.roles = roles; } public List
getRoles() { return roles; }}
public class Role implements Serializable {    private Integer roleId;    private String roleName;    private String roleDesc;    // Role 到 User 的映射关系    private List
users; public void setUsers(List
users) { this.users = users; } public List
getUsers() { return users; }}

3. 持久层接口

定义 UserDao 接口。

public interface IUserDao {    // 查询所有用户并获取角色信息    List
findAll();}

4. MyBatis 配置文件

配置 UserDao。


5. 测试类

测试 User 到 Role 的映射关系。

public class UserTest {    private InputStream in;    private SqlSessionFactory factory;    private SqlSession sqlSession;    private IUserDao userDao;    @Before    public void init() throws IOException {        in = Resources.getResourceAsStream("SqlMapConfig.xml");        factory = new SqlSessionFactoryBuilder().build(in);        sqlSession = factory.openSession(true);        userDao = sqlSession.getMapper(IUserDao.class);    }    @After    public void destory() throws Exception {        sqlSession.close();        in.close();    }    // 测试查询所有用户并获取角色信息    @Test    public void testFindAll() {        List
users = userDao.findAll(); for (User user : users) { System.out.println("这是一条记录:" + user); System.out.println("关联的角色:" + user.getRoles()); } }}

转载地址:http://okerz.baihongyu.com/

你可能感兴趣的文章
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
MySQL —— 视图
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
MySQL 中的外键检查设置:SET FOREIGN_KEY_CHECKS = 1
查看>>
Mysql 中的日期时间字符串查询
查看>>
mysql 中索引的问题
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>