博客
关于我
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 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>