resultType实现一对多的查询

1.1    resultType

1.1.1    sql语句

确定查询的主表:订单表

确定查询的关联表:用户表

         关联查询使用内链接?还是外链接?

         由于orders表中有一个外键(user_id),通过外键关联查询用户表只能查询出一条记录,可以使用内链接。

SELECT

 orders.*,

 USER.username,

 USER.sex,

 USER.address

FROM

 orders,

 USER

WHERE orders.user_id = user.id

1.1.2    创建pojo

将上边sql查询的结果映射到pojo中,pojo中必须包括所有查询列名。

原始的Orders.java不能映射全部字段,需要新创建的pojo

创建一个pojo继承包括查询字段较多的po类。

package cn.itcast.mybatis.po;


//通过此类映射订单和用户查询的结果,让此类继承包括 字段较多的pojo类
public class OrdersCustom extends Orders{

//添加用户属性
/*USER.username,
  USER.sex,
  USER.address */

private String username;
private String sex;
private String address;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}

1.1.3   mapper.xml

resultType实现一对多的查询

1.1.4    mapper.java

resultType实现一对多的查询

1.1.5    测试信息

package cn.itcast.mybatis.mapper;


import static org.junit.Assert.*;


import java.io.InputStream;
import java.util.List;


import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.apache.logging.log4j.core.config.Order;
import org.junit.Before;
import org.junit.Test;


import cn.itcast.mybatis.po.Orders;
import cn.itcast.mybatis.po.OrdersCustom;


public class OrdersCustomMapperTest {
  private SqlSessionFactory sqlSessionFactory;
@Before
public void setUp() throws Exception {
//mybatis配置文件
String resource="sqlMapConfig.xml";
InputStream inputStream;
//得到配置文件数据流
inputStream = Resources.getResourceAsStream(resource);
//创建会话工厂
sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);

}


@Test
public void testFindOrdersUser() {
SqlSession sqlsession=sqlSessionFactory.openSession();
//生成mapper代理的方式;
OrdersCustomMapper orderCustomMapper=sqlsession.getMapper(OrdersCustomMapper.class);
//查询结果以一个list列表的形式表现出来;
List<OrdersCustom> list;

try {
list = orderCustomMapper.findOrdersUser();
System.out.println(list);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

}
}