博客
关于我
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 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>