博客
关于我
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主从复制 master和slave配置的参数大全
查看>>
MySQL主从复制几个重要的启动选项
查看>>
MySQL主从复制及排错
查看>>
mysql主从复制及故障修复
查看>>
MySQL主从复制的原理和实践操作
查看>>
webpack loader配置全流程详解
查看>>
mysql主从复制,读写分离,半同步复制实现
查看>>
MySQL主从失败 错误Got fatal error 1236解决方法
查看>>
MySQL主从架构与读写分离实战
查看>>
MySQL主从篇:死磕主从复制中数据同步原理与优化
查看>>
mysql主从配置
查看>>
MySQL之2003-Can‘t connect to MySQL server on ‘localhost‘(10038)的解决办法
查看>>
MySQL之CRUD
查看>>
MySQL之DML
查看>>
Mysql之IN 和 Exists 用法
查看>>
MYSQL之REPLACE INTO和INSERT … ON DUPLICATE KEY UPDATE用法
查看>>
MySQL之SQL语句优化步骤
查看>>
MYSQL之union和order by分析([Err] 1221 - Incorrect usage of UNION and ORDER BY)
查看>>
Mysql之主从复制
查看>>
MySQL之函数
查看>>