Mybatis学习笔记--多表查询

  • @param userId

*/

User findById(Integer userId);

}

实现账户的dao接口:

public interface IAccountDao{

/**

  • 查询所有账户

  • @return

*/

List findAll();

/**

  • 查询所有账户,并且带有用户名称和地址信息

  • @return

*/

List findAllAccount();

}

实现一对一关系:

创建账户配置文件IAccountDao.xml:实现查询账户时同时的到账户对应的用户信息

<?xml version="1.0" encoding="UTF-8"?>

select a.*,u.username,u.address from account a, user u where u.id =a.id;

select u.*,a.id as aid,a.uid,a.money from account a, user u where u.id =a.uid;

测试代码:一对一操作

public class AccountTest {

private InputStream in;

private SqlSession sqlSession;

private IAccountDao accountDao;

@Before//再测试方法执行之前执行

public void init() throws Exception{

//1.读取配置文件,生成字节输入流

in= Resources.getResourceAsStream(“SqlMapConfig.xml”);

//2.创建SqlSessionFactory工厂,获取SqlSessionFactory对象

SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(in);

//3.使用工厂生产SqlSession对象

sqlSession=factory.openSession();

//4.使用SqlSession创建Dao接口的代理对象

accountDao=sqlSession.getMapper(IAccountDao.class);

}

@After//用于在测试方法执行之后执行

public void destroy() throws Exception{

//提交事务

sqlSession.commit();

//6.释放资源

sqlSession.close();

in.close();

}

/**

  • 测试查询所有

*/

@Test

public void testFindAll(){

//使用代理对象执行方法

List accounts=accountDao.findAll();

for (Account account : accounts){

System.out.println(“每个account信息”);

System.out.println(account);

System.out.println(account.getUser());

}

}

/**

  • 测试查询所有账户,包括用户名和地址

*/

@Test

public void testFindAllAccountUser(){

//使用代理对象执行方法

List aus=accountDao.findAllAccount();

for (AccountUser au : aus){

System.out.println(au);

}

}

}

测试 testFindAll方法

在这里插入图片描述

测试testFindAllAccountUser方法

在这里插入图片描述

实现一对多关系:

创建用户配置文件:IUserDao.xml:实现查询用户同时得到用户下的所有账户

<?xml version="1.0" encoding="UTF-8"?>

select * from user u left outer join account a on u.id =a.uid

测试代码:一对多代码

public class UserTest {

private InputStream in;

private SqlSession sqlSession;

private IUserDao userDao;

@Before//再测试方法执行之前执行

public void init() throws Exception{

//1.读取配置文件,生成字节输入流

in= Resources.getResourceAsStream(“SqlMapConfig.xml”);

//2.创建SqlSessionFactory工厂,获取SqlSessionFactory对象

SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(in);

//3.使用工厂生产SqlSession对象

sqlSession=factory.openSession();

//4.使用SqlSession创建Dao接口的代理对象

userDao=sqlSession.getMapper(IUserDao.class);

}

@After//用于在测试方法执行之后执行

public void destroy() throws Exception{

//提交事务

sqlSession.commit();

//6.释放资源

sqlSession.close();

in.close();

}

/**

  • 测试查询所有

*/

@Test

public void testFindAll(){

//5.使用代理对象执行方法

List users=userDao.findAll();

for (User user : users){

System.out.println("-----------每个用户的信息----------");

System.out.println(user);

System.out.println(user.getAccounts());

}

}

}

测试testFindAll方法:

在这里插入图片描述

用户和角色案例


实现多对多关系: 一个用户可以又多个角色,一个角色可以赋予多个用户

建立两张表:让用户表和角色表具有多对多的关系。需要使用中间表,中间表中包含各子的主键,在中间表中是外键

#创建角色表

create table role(

id int(11) not null comment ‘编号’,

role_name varchar(30) default null comment ‘角色名称’,

role_desc varchar(60) default null comment ‘角色描述’,

primary key(id)

)engine=InnoDB default charset=utf8;

//#创建用户角色表(中间表)

create table user_role(

uid int(11) not null comment ‘用户编号’,

rid int(11) not null comment ‘角色编号’,

primary key (uid,rid),

key FK_Reference_10(RID),

constraint FK_Reference_10 foreign key (rid) references role (id),

constraint FK_Reference_9 foreign key(uid) references user (id)

)engine=InnoDB default charset=utf8;

在这里插入图片描述

目录结构:

在这里插入图片描述

建立两个实体类:

实体类Role:

/**

  • @Author: Ly

  • @Date: 2020-07-16 08:22

*/

public class Role implements Serializable {

private Integer roleId;

private String roleName;

private String roleDesc;

//多对多的关系映射,一个角色可以赋予多个用户

private List users;

public List getUsers() {

return users;

}

public void setUsers(List users) {

this.users = users;

}

public Integer getRoleId() {

return roleId;

}

public void setRoleId(Integer roleId) {

this.roleId = roleId;

}

public String getRoleName() {

return roleName;

}

public void setRoleName(String roleName) {

this.roleName = roleName;

}

public String getRoleDesc() {

return roleDesc;

}

public void setRoleDesc(String roleDesc) {

this.roleDesc = roleDesc;

}

@Override

public String toString() {

return “Role{” +

“roleId=” + roleId +

“, roleName=’” + roleName + ‘’’ +

“, roleDesc=’” + roleDesc + ‘’’ +

‘}’;

}

}

实体类User:

/**

  • @Author: Ly

  • @Date: 2020-07-12 11:15

*/

public class User implements Serializable {

private Integer id;

private String username;

private String address;

private String sex;

private Date birthday;

//多对多的关系映射,一个用户可以具备多个角色

private List roles;

public List getRoles() {

return roles;

}

public void setRoles(List roles) {

this.roles = roles;

}

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getUsername() {

return username;

}

public void setUsername(String username) {

this.username = username;

}

public String getAddress() {

return address;

}

public void setAddress(String address) {

this.address = address;

}

public String getSex() {

return sex;

}

public void setSex(String sex) {

this.sex = sex;

}

public Date getBirthday() {

return birthday;

}

public void setBirthday(Date birthday) {

this.birthday = birthday;

}

@Override

public String toString() {

return “User{” +

“id=” + id +

“, username=’” + username + ‘’’ +

“, address=’” + address + ‘’’ +

“, sex=’” + sex + ‘’’ +

“, birthday=” + birthday +

‘}’;

}

}

创建Role类的dao接口:

/**

  • @Author: Ly

  • @Date: 2020-07-16 08:24

*/

public interface IRoleDao {

/**

  • 查询所有角色

  • @return

*/

List findAll();

}

创建User类的dao接口:

/**

  • @Author: Ly

  • @Date: 2020-07-12 11:29

*/

public interface IUserDao {

/**

  • 查询所有用户

  • @return

*/

List findAll();

}

配置IRoleDao的映射配置文件:IRoleDao.xml

<?xml version="1.0" enc ``` 【一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义】 浏览器打开:qq.cn.hn/FTf 免费领取 ``` oding="UTF-8"?>

select u.*,r.id as rid,r.role_name,r.role_desc from role r

left outer join user_role ur on r.id = ur.rid

left outer join user u on u.id = ur.uid

配置IUserDao的映射配置文件:IUserDao.xml

<?xml version="1.0" encoding="UTF-8"?>

select u.*,r.id as rid,r.role_name,r.role_desc from user u

left outer join user_role ur on u.id = ur.uid

left outer join role r on r.id = ur.rid

测试代码:角色对用户查询

public class RoleTest {

private InputStream in;

private SqlSession sqlSession;

private IRoleDao roleDao;

@Before//再测试方法执行之前执行

public void init() throws Exception{

//1.读取配置文件,生成字节输入流

in= Resources.getResourceAsStream(“SqlMapConfig.xml”);

//2.创建SqlSessionFactory工厂,获取SqlSessionFactory对象

SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(in);

//3.使用工厂生产SqlSession对象

sqlSession=factory.openSession();

//4.使用SqlSession创建Dao接口的代理对象

roleDao=sqlSession.getMapper(IRoleDao.class);

}

@After//用于在测试方法执行之后执行

public void destroy() throws Exception{

//提交事务

sqlSession.commit();

//6.释放资源

sqlSession.close();

in.close();

}

/**

  • 测试查询所有

*/

@Test

public void testFindAll(){

//使用代理对象执行方法

List roles=roleDao.findAll();

for (Role role :roles){

System.out.println("–角色信息–");

System.out.println(role);

System.out.println(role.getUsers());

}

}

}

测试结果:

在这里插入图片描述

测试代码:用户对角色查询

public class UserTest {

private InputStream in;

private SqlSession sqlSession;

private IUserDao userDao;

@Before//再测试方法执行之前执行

public void init() throws Exception{

//1.读取配置文件,生成字节输入流

in= Resources.getResourceAsStream(“SqlMapConfig.xml”);

//2.创建SqlSessionFactory工厂,获取SqlSessionFactory对象

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值