Mybatis复杂对象映射配置ResultMap的association

  • association:映射到POJO的某个复杂类型属性,比如订单order对象里面包含user对象

表结构

项目结构

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>net.cyb</groupId>
<artifactId>cyb-mybatis</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.4</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.20</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.30</version>
</dependency>
</dependencies>
</project>

mybatis-config-xml

<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 引入外部配置文件 -->
<properties resource="config/db.properties"></properties>
<!--下划线自动映射驼峰字段-->
<!-- <settings>-->
<!-- <setting name="mapUnderscoreToCamelCase" value="true"/>-->
<!-- </settings>-->
<!-- 数据库链接相关 -->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="${db.driver}" />
<property name="url" value="${db.url}" />
<property name="username" value="${db.username}" />
<property name="password" value="${db.password}" />
</dataSource>
</environment>
</environments>
<mappers>
<!-- 添加映射文件 -->
<mapper resource="mapper/VideoMapper.xml" />
<mapper resource="mapper/VideoOrderMapper.xml" />
</mappers>
</configuration>

db.properties

db.driver=com.mysql.cj.jdbc.Driver
db.url=jdbc:mysql://127.0.0.1:3306/cybclass
db.username=root
db.password=root

VideoOrderMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--
namespace:名称空间,一般需要保持全局唯一,最好是和dao层的java接口一致。可以映射sql语句到对应的方法名称和参数、返回类型
-->
<mapper namespace="net.cybclass.online.dao.VideoOrderMapper">
<resultMap id="VideoOrderResultMap" type="net.cybclass.online.domain.VideoOrder">
<id column="id" property="id"></id>
<result column="user_id" property="user_id"></result>
<result column="out_trade_no" property="out_trade_no"></result>
<result column="create_time" property="create_time"></result>
<result column="state" property="state"></result>
<result column="total_fee" property="total_fee"></result>
<result column="video_id" property="video_id"></result>
<result column="video_title" property="video_title"></result>
<result column="video_img" property="video_img"></result>
<!--
配置属性一对一
property:对应VideoOrder里面的user属性名
javaType:这个属性的类型
-->
<association property="user" javaType="net.cybclass.online.domain.User">
<id column="user_id" property="id"></id>
<result column="name" property="name"></result>
<result column="pwd" property="pwd"></result>
<result column="phone" property="phone"></result>
<result column="head_img" property="head_img"></result>
<result column="create_time_u" property="create_time"></result>
</association>
</resultMap>
<!--一对一关联查询订单,订单内容包含用户属性-->
<select id="queryVideoOrderList" resultMap="VideoOrderResultMap">
select
v.id,
v.out_trade_no,
v.create_time,
v.state,
v.total_fee,
v.video_id,
v.video_title,
v.user_id,
v.video_img,
u.name,
u.pwd,
u.phone,
u.head_img,
u.create_time create_time_u
from video_order v left join user u on v.user_id=u.id
</select>
</mapper>

VideoOrder.java

package net.cybclass.online.domain;

import java.util.Date;

public class VideoOrder {
private int id;
private String out_trade_no;
private int state;
private int total_fee;
private int video_id;
private String video_title;
private String video_img;
private int user_id;
private Date create_time;
private User user; public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getOut_trade_no() {
return out_trade_no;
} public void setOut_trade_no(String out_trade_no) {
this.out_trade_no = out_trade_no;
} public int getState() {
return state;
} public void setState(int state) {
this.state = state;
} public int getTotal_fee() {
return total_fee;
} public void setTotal_fee(int total_fee) {
this.total_fee = total_fee;
} public int getVideo_id() {
return video_id;
} public void setVideo_id(int video_id) {
this.video_id = video_id;
} public String getVideo_title() {
return video_title;
} public void setVideo_title(String video_title) {
this.video_title = video_title;
} public String getVideo_img() {
return video_img;
} public void setVideo_img(String video_img) {
this.video_img = video_img;
} public int getUser_id() {
return user_id;
} public void setUser_id(int user_id) {
this.user_id = user_id;
} public Date getCreate_time() {
return create_time;
} public void setCreate_time(Date create_time) {
this.create_time = create_time;
} public User getUser() {
return user;
} public void setUser(User user) {
this.user = user;
} @Override
public String toString() {
return "VideoOrder{" +
"id=" + id +
", out_trade_no='" + out_trade_no + '\'' +
", state=" + state +
", total_fee=" + total_fee +
", video_id=" + video_id +
", video_title='" + video_title + '\'' +
", video_img='" + video_img + '\'' +
", user_id=" + user_id +
", create_time=" + create_time +
", user=" + user +
'}';
}
}

User.java

package net.cybclass.online.domain;

import java.util.Date;

public class User {
//内码
private int id;
//用户
private String name;
//密码
private String pwd;
//手机号
private String phone;
//头像
private String head_img;
//创建时间
private Date create_time; public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPwd() {
return pwd;
} public void setPwd(String pwd) {
this.pwd = pwd;
} public String getPhone() {
return phone;
} public void setPhone(String phone) {
this.phone = phone;
} public String getHead_img() {
return head_img;
} public void setHead_img(String head_img) {
this.head_img = head_img;
} public Date getCreate_time() {
return create_time;
} public void setCreate_time(Date create_time) {
this.create_time = create_time;
} @Override
public String toString() {
return "User{" +
"id=" + id +
", name='" + name + '\'' +
", pwd='" + pwd + '\'' +
", phone='" + phone + '\'' +
", head_img='" + head_img + '\'' +
", create_time=" + create_time +
'}';
}
}

VideoOrderMapper.java

package net.cybclass.online.dao;

import net.cybclass.online.domain.VideoOrder;

import java.util.List;

public interface VideoOrderMapper {
/**
* 查询全部订单,关联用户信息
* @return
*/
List<VideoOrder> queryVideoOrderList();
}

SqlSessionDemo.java

package net.cybclass.online;

import net.cybclass.online.dao.VideoMapper;
import net.cybclass.online.dao.VideoOrderMapper;
import net.cybclass.online.domain.Video;
import net.cybclass.online.domain.VideoOrder;
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 java.io.IOException;
import java.io.InputStream;
import java.util.*; public class SqlSessionDemo {
public static void main(String[] args) throws IOException {
String resouce="config/mybatis-config.xml";
InputStream resourceAsStream = Resources.getResourceAsStream(resouce);
SqlSessionFactory build = new SqlSessionFactoryBuilder().build(resourceAsStream);
try(SqlSession session=build.openSession()){
VideoOrderMapper mapper = session.getMapper(VideoOrderMapper.class);
//resultMap association关联查询
List<VideoOrder> list=mapper.queryVideoOrderList();
System.out.println(list);
}catch (Exception e){
e.printStackTrace();
}
}
}

Mybatis ResultMap复杂对象一对一查询结果映射之association的更多相关文章

  1. mybatis学习笔记(10)-一对一查询

    mybatis学习笔记(10)-一对一查询 标签: mybatis mybatis学习笔记10-一对一查询 resultType实现 resultMap实现 resultType和resultMap实 ...

  2. MyBatis——一对多、一对一关系,collection、association

    实体类两个: user类: package com.pojo; /** *用户 */ public class User{ private int userId;//用户ID private Stri ...

  3. JAVAEE——Mybatis第二天:输入和输出映射、动态sql、关联查询、Mybatis整合spring、Mybatis逆向工程

    1. 学习计划 1.输入映射和输出映射 a) 输入参数映射 b) 返回值映射 2.动态sql a) If标签 b) Where标签 c) Sql片段 d) Foreach标签 3.关联查询 a) 一对 ...

  4. Mybatis学习总结(六)——高级映射(一对一,一对多,多对多)

    一.订单商品数据模型 1.数据库执行脚本 创建数据库表代码: /*Table structure for table `t_user` */ CREATE TABLE t_user ( id INT ...

  5. Mybatis之旅第四篇-输入输出映射

    一.引言 在日常开发用到mybatis时,因为实际的开发业务场景很复杂,不论是输入的查询条件,还是返回的结果,经常是需要根据业务来定制,这个时候我们就需要自己来定义一些输入和输出映射 二.parame ...

  6. Mybatis中的多表查询 多对一,一对多

    示例:用户和账户 一个用户可以有多个账户 一个账户只能属于一个用户(多个账户也可以属于同一个用户) 步骤: 1.建立两张表:用户表,账户表 让用户表和账户表之间具备一对多的关系:需要使用外键在账户表中 ...

  7. Mybatis学习系列(二)Mapper映射文件

    Mapper映射文件,作用是用来配置SQL映射语句,根据不同的SQL语句性质,使用不同的标签,mapper文件中常用的标签有<iselect>.<insert>.<upd ...

  8. Mybatis学习笔记(五) —— Mapper.xml(输入映射和输出映射)

    一.parameterType(输入类型) 1.1 传递简单类型 <!-- 根据用户id查询用户 --> <select id="queryUserById" p ...

  9. 18_高级映射:一对一查询(使用resultMap)

    [简述] 数据库模型和数据等信息与上一篇博文相同. 需求也同上一篇博文. [工程截图] [User.java]POJO package cn.higgin.mybatis.po; import jav ...

  10. mybatis由浅入深day02_2一对一查询_2.3方法二:resultMap_resultType和resultMap实现一对一查询小结

    2.3 方法二:resultMap 使用resultMap,定义专门的resultMap用于映射一对一查询结果. 2.3.1 sql语句 同resultType实现的sql SELECT orders ...

随机推荐

  1. java调用webservice接口

    1.直接AXIS调用远程的webservice 注意:不同版本的Axis相差很大,大家最好以apache网站上的例子为准,这里仅仅用于说明其基本用法. import org.apache.axis.c ...

  2. grafana模板参考

    空的,把面板都删除了 { "__inputs": [ { "name": "DS_PROMETHEUS", "label" ...

  3. turltle模块详解

    引言:turtle(海龟)模块,我们是用它来进行画图的,基本上就是画简单的直线,点,和曲线. 你可以把它想成一个小海龟,在沙滩上行走,然后留下的各种痕迹,使用Turtle模块可以绘制很多精美的图形. ...

  4. rsync备份服务器部署详情

    rsync  -avz --bwlimit=1024M /data/wanxhe  rsync_backup@10.x.x.38::backup/gpu007/data/ --password-fil ...

  5. Android 13 - Media框架(9)- NuPlayer::Decoder

    关注公众号免费阅读全文,进入音视频开发技术分享群! 这一节我们将了解 NuPlayer::Decoder,学习如何将 MediaCodec wrap 成一个强大的 Decoder.这一节会提前讲到 M ...

  6. 中国十大IT技术社区,你都知道哪些?

    中国5大新型IT技术社区与5大传统IT技术社区,你都知道哪些? 社区是聚集一类具有相同爱好或者相同行业的群体,IT技术社区就是聚集了IT行业内的技术人,在技术社区可以了解到行业的最新进展,学习最前沿的 ...

  7. 从零开始写 Docker(十七)---容器网络实现(中):为容器插上”网线“

    本文为从零开始写 Docker 系列第十七篇,利用 linux 下的 Veth.Bridge.iptables 等等相关技术,构建容器网络模型,为容器插上"网线". 完整代码见:h ...

  8. 还在拼冗长的WhereIf吗?100行代码解放这个操作

    通常我们在做一些数据过滤的操作的时候,经常需要做一些判断再进行是否要对其进行条件过滤. 普通做法 最原始的做法我们是先通过If()判断是否需要进行数据过滤,然后再对数据源使用Where来过滤数据. 示 ...

  9. kettle从入门到精通 第十二课 kettle java代码过滤记录、利用Janino计算Java表达式

    1.下图通过简单的示例讲解了根据java代码过滤记录和利用Janino计算Java表达式两个组件. 2.根据java代码过滤记录 1)步骤名称:自定义 2)接收匹配的行的步骤(可选):下面条件(jav ...

  10. sshd服务部署

    sshd服务部署 软件安装修改配置文件启动使用​ 1.搭建所有服务的套路 关闭防火墙和selinux(实验环境都先关闭掉) 配置yum源(公网源或者本地源) 软件安装和检查 了解并修改配置文件 启动服 ...