博客
关于我
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-架构篇
查看>>
MySQL-索引的分类(聚簇索引、二级索引、联合索引)
查看>>
Mysql-触发器及创建触发器失败原因
查看>>
MySQL-连接
查看>>
mysql-递归查询(二)
查看>>
MySQL5.1安装
查看>>
mysql5.5和5.6版本间的坑
查看>>
mysql5.5最简安装教程
查看>>
mysql5.6 TIME,DATETIME,TIMESTAMP
查看>>
mysql5.6.21重置数据库的root密码
查看>>
Mysql5.6主从复制-基于binlog
查看>>
MySQL5.6忘记root密码(win平台)
查看>>
MySQL5.6的Linux安装shell脚本之二进制安装(一)
查看>>
MySQL5.6的zip包安装教程
查看>>
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>