文档章节

MyBatis的一对一查询实现方式

丶KKdo
 丶KKdo
发布于 2016/08/17 15:18
字数 685
阅读 35
收藏 0
点赞 0
评论 0

 

Mybatis对查询结果的映射有两种, 一种是resultMap, 还有一种是resultType.

reusltType模式实现的映射需要保证数据表中的列名和映射对象的属性名要一致.

resultMap则可以由自己灵活配置.

要实现一对一的查询,先建立两个表, 一个stu表, 和一个card表, 为了简单就少列出几个字段.

-- stu表
CREATE TABLE `f_stu` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `name` varchar(10) NOT NULL COMMENT '姓名',
  `study_num` varchar(20) NOT NULL COMMENT '学号',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8

-- card表
CREATE TABLE `f_idcards` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `card_num` varchar(18) DEFAULT NULL COMMENT '卡号',
  `u_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `u_id` (`u_id`),
  CONSTRAINT `f_idcards_ibfk_1` FOREIGN KEY (`u_id`) REFERENCES `f_stu` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8

然后, 引入mybatis需要的jar包, 编写主配置文件mappingConfig.xml:

这里并未使用spring,所以事务交给他本身管理.

<!-- mappingConfig.xml -->
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD SQL Map Config 3.0//EN"  
	"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
	<properties resource="jdbc.properties"></properties>
	<typeAliases>
		<package name="com.mybatis.po"/>
	</typeAliases>
	<environments default="development">
		<environment id="development">
			<transactionManager type="JDBC" />
			<dataSource type="POOLED">
				<property name="driver" value="${jdbc.driverClassName}" />
				<property name="url" value="${jdbc.url}" />
				<property name="username" value="${jdbc.username}" />
				<property name="password" value="${jdbc.password}" />
			</dataSource>
		</environment>
	</environments>
	<!-- 加载配置文件 -->
	<mappers>
		<mapper resource="mapper/StuMapper.xml"/>
	</mappers>
</configuration>

接下来,编写对应的StuMapper.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">
<mapper namespace="com.mybatis.dao.StuMapper">

	<!-- 查询学生信息和卡号 -->
	<select id="findStuAndCard" resultType="stuCardResult">
		SELECT A.*, B.card_num
		FROM f_IDcards B, f_stu	A
		WHERE A.id = B.u_id
	</select>
</mapper>

resultType的结果是自定义的pojo:

将查询出来没有的列名映射过去;

public class StuCardResult extends Stu{
	private String card_num;

	public String getCard_num() {
		return card_num;
	}

	public void setCard_num(String card_num) {
		this.card_num = card_num;
	}
}

接下来,编写Mapper代理接口:

public interface StuMapper {
	
	public List<StuCardResult> findStuAndCard() throws Exception;
	
}

由于还没有使用spring,所以在测试的时候为了方便, 编写一个工具类用来获取sqlSession:

public class GetSqlSessionUtil {

	private static SqlSessionFactory sqlSessionFactory;
	
	public static SqlSession getSqlSession() throws Exception {
		if(sqlSessionFactory == null) {
			String resource = "mappingConfig.xml";
			InputStream inputStream = Resources.getResourceAsStream(resource);
			sqlSessionFactory =  new SqlSessionFactoryBuilder().build(inputStream);
		}
		return sqlSessionFactory.openSession();
	}
}

最后,可以来测试一下resultType的方法:

public class StuTest {
	@Test
	public void test() throws Exception {
		SqlSession sqlSession = GetSqlSessionUtil.getSqlSession();
		StuMapper stuMapper  = sqlSession.getMapper(StuMapper.class);
		List<StuCardResult> list = stuMapper.findStuAndCard();
		if(list != null) {
			for(StuCardResult result : list) {
				System.out.println(result.getCard_num());
			}
		}
	}
}

运行测试单元:

结果正确.

再使用resultMap来进行查询结果映射:

修改配置文件:

<!-- StuMapper.xml -->
<!-- 定义resultMap -->
	<resultMap type="stu" id="stuAndCardResultMap">
		<id column="id" property="id"/>
		<result column="name" property="name"/>
		<result column="study_num" property="studyNum"/>
		<association property="card" column="u_id" javaType="Card">
			<result column="card_num" property="cardNum"/>
		</association>
	</resultMap>

    <select id="findStuAndCardResultMap" resultMap="stuAndCardResultMap">
		SELECT A.*, B.card_num
		FROM f_IDcards B, f_stu	A
		WHERE A.id = B.u_id
	</select>

然后修改一下Stu.java类,添加一个card属性进去. 

    private String studyNum;   //与property映射过来的属性名称一致
	private Card card;

mapper代理类中添加响应的接口,然后进行测试:

这样就Ok了.

© 著作权归作者所有

共有 人打赏支持
丶KKdo
粉丝 1
博文 22
码字总数 13683
作品 0
成都
程序员
Java面试----2018年MyBatis常见实用面试题整理

Java面试----2018年MyBatis常见实用面试题整理 1、什么是MyBatis? 答:MyBatis是一个可以自定义SQL、存储过程和高级映射的持久层框架。 2、讲下MyBatis的缓存 答:MyBatis的缓存分为一级缓存...

优惠券活动 ⋅ 04/29 ⋅ 0

Mybatis与Ibatis比较

随着开发团队转投Google Code旗下,ibatis3.x正式更名为Mybatis 虽然从正式版发布至今也有近一年时间,官方也非常友好的提供了中文版的使用手册,不过相信很多人还在项目中使用ibatis2.x版本...

北方攻城师 ⋅ 2015/04/05 ⋅ 1

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

mybatis学习笔记(10)-一对一查询 标签: mybatis [TOC] 本文使用两种方式(resultType和resultMap)实现一对一查询,查询订单信息,关联查询创建订单的用户信息 resultType实现 sql语句 确定查...

brianway ⋅ 2016/03/01 ⋅ 0

MyBatis学习整理0

学习java的基本都会“ssh”,我也不例外,其中就包括了hibernate,当时感觉挺神奇的,去年开始接触mybatis,一对比发现,这mybatis有不少优点。 下面分享一下我在学习mybatis的时候整理的内容...

阿信sxq ⋅ 2016/08/19 ⋅ 2

Mybatis3.4.x技术内幕(二十一):参数设置、结果封装、级联查询、延迟加载原理分析

Mybatis在执行查询时,其参数设置、结果封装、级联查询、延迟加载,是最基本的功能和用法,我们有必要了解其工作原理,重点阐述级联查询和延迟加载。 1、MetaObject MetaObject用于反射创建对...

祖大俊 ⋅ 2016/09/16 ⋅ 0

MyBatis学习总结(五)——实现关联表查询

一、一对一关联 1.1、提出需求   根据班级id查询班级信息(带老师的信息) 1.2、创建表和数据   创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就...

Carl_ ⋅ 2015/08/12 ⋅ 0

MyBatis学习总结(五)——实现关联表查询

一、一对一关联 1.1、提出需求   根据班级id查询班级信息(带老师的信息) 1.2、创建表和数据   创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就...

Carl_ ⋅ 2015/08/12 ⋅ 0

MyBatis 实践 -动态SQL/关联查询

标签: Java与存储 动态SQL 动态SQL提供了对SQL语句的灵活操作,通过表达式进行判断,对SQL进行拼接/组装. if 对查询条件进行判断,如果输入参数不为空才进行查询条件的拼接. mapper 会自动处理...

hanqing280441589 ⋅ 2016/02/28 ⋅ 0

MyBatis之使用resultMap实现高级映射

对于数据库中对表的增删改查操作,我们知道增删改都涉及的是单表,而只有查询操作既可以设计到单表操作又可以涉及到多表操作,所以对于输入映射parameterType而言是没有所谓的高级映射的,也...

瑟青豆 ⋅ 06/20 ⋅ 0

SSH框架之MyBatis专题3:关联关系查询

1 关联查询 当查询内容涉及具有关联关系的多个表时,就需要使用关联关系查询。根据表与表之间的关联关系的不同,关联查询分为四种: 1、一对一关联查询; 2、一对多关联查询; 3、多对一关联...

糖醋白糖 ⋅ 04/06 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

个人博客的运营模式能否学习TMALL天猫质量为上?

心情随笔|个人博客的运营模式能否学习TMALL天猫质量为上? 中国的互联网已经发展了很多年了,记得在十年前,个人博客十分流行,大量的人都在写博客,而且质量还不错,很多高质量的文章都是在...

原创小博客 ⋅ 今天 ⋅ 0

JavaScript零基础入门——(十一)JavaScript的DOM操作

JavaScript零基础入门——(十一)JavaScript的DOM操作 大家好,欢迎回到我们的JavaScript零基础入门。最近有些同学问我说,我讲的的比书上的精简不少。其实呢,我主要讲的是我在开发中经常会...

JandenMa ⋅ 今天 ⋅ 0

volatile和synchronized的区别

volatile和synchronized的区别 在讲这个之前需要先了解下JMM(Java memory Model :java内存模型):并发过程中如何处理可见性、原子性、有序性的问题--建立JMM模型 详情请看:https://baike.b...

MarinJ_Shao ⋅ 今天 ⋅ 0

深入分析Kubernetes Critical Pod(一)

Author: xidianwangtao@gmail.com 摘要:大家在部署Kubernetes集群AddOn组件的时候,经常会看到Annotation scheduler.alpha.kubernetes.io/critical-pod"="",以表示这是一个关键服务,那你知...

WaltonWang ⋅ 今天 ⋅ 0

原子性 - synchronized关键词

原子性概念 原子性提供了程序的互斥操作,同一时刻只能有一个线程能对某块代码进行操作。 原子性的实现方式 在jdk中,原子性的实现方式主要分为: synchronized:关键词,它依赖于JVM,保证了同...

dotleo ⋅ 今天 ⋅ 0

【2018.06.22学习笔记】【linux高级知识 14.4-15.3】

14.4 exportfs命令 14.5 NFS客户端问题 15.1 FTP介绍 15.2/15.3 使用vsftpd搭建ftp

lgsxp ⋅ 今天 ⋅ 0

JeeSite 4.0 功能权限管理基础(Shiro)

Shiro是Apache的一个开源框架,是一个权限管理的框架,实现用户认证、用户授权等。 只要有用户参与一般都要有权限管理,权限管理实现对用户访问系统的控制,按照安全规则或者安全策略控制用户...

ThinkGem ⋅ 昨天 ⋅ 0

python f-string 字符串格式化

主要内容 从Python 3.6开始,f-string是格式化字符串的一种很好的新方法。与其他格式化方式相比,它们不仅更易读,更简洁,不易出错,而且速度更快! 在本文的最后,您将了解如何以及为什么今...

阿豪boy ⋅ 昨天 ⋅ 0

Python实现自动登录站点

如果我们想要实现自动登录,那么我们就需要能够驱动浏览器(比如谷歌浏览器)来实现操作,ChromeDriver 刚好能够帮助我们这一点(非谷歌浏览器的驱动有所不同)。 一、确认软件版本 首先我们...

blackfoxya ⋅ 昨天 ⋅ 0

线性回归原理和实现基本认识

一:介绍 定义:线性回归在假设特证满足线性关系,根据给定的训练数据训练一个模型,并用此模型进行预测。为了了解这个定义,我们先举个简单的例子;我们假设一个线性方程 Y=2x+1, x变量为商...

wangxuwei ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部