文档章节

MyBatis的一对一查询实现方式

丶KKdo
 丶KKdo
发布于 2016/08/17 15:18
字数 685
阅读 42
收藏 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
博文 24
码字总数 13683
作品 0
成都
程序员
私信 提问
Java面试----2018年MyBatis常见实用面试题整理

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

优惠券活动
04/29
0
0
mybatis学习笔记(10)-一对一查询

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

brianway
2016/03/01
117
0
Mybatis与Ibatis比较

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

北方攻城师
2015/04/05
0
1
MyBatis学习总结(五)——实现关联表查询

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

Carl_
2015/08/12
0
0
MyBatis学习总结(五)——实现关联表查询

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

Carl_
2015/08/12
0
0

没有更多内容

加载失败,请刷新页面

加载更多

PHP生成CSV之内部换行

当我们使用PHP将采集到的文件内容保存到csv文件时,往往需要将采集内容进行二次过滤处理才能得到需要的内容。比如网页中的换行符,空格符等等。 对于空格等处理起来都比较简单,这里我们单独...

豆花饭烧土豆
53分钟前
1
0
使用 mjml 生成 thymeleaf 邮件框架模板

发邮件算是系统开发的一个基本需求了,不过搞邮件模板实在是件恶心事,估计搞过的同仁都有体会。 得支持多种客户端 支持响应式 疼彻心扉的 outlook 多数客户端只支持 inline 形式的 css 布局...

郁也风
56分钟前
4
0
让哲学照亮我们的人生——读《医务工作者需要学点哲学》有感2600字

让哲学照亮我们的人生——读《医务工作者需要学点哲学》有感2600字: 作者:孙冬梅;以前读韩国前总统朴槿惠的著作《绝望锻炼了我》时,里面有一句话令我印象深刻,她说“在我最困难的时期,...

原创小博客
今天
3
0
JAVA-四元数类

public class Quaternion { private final double x0, x1, x2, x3; // 四元数构造函数 public Quaternion(double x0, double x1, double x2, double x3) { this.x0 = ......

Pulsar-V
今天
17
0
Xshell利用Xftp传输文件,使用pure-ftpd搭建ftp服务

Xftp传输文件 如果已经通过Xshell登录到服务器,此时可以使用快捷键ctrl+alt+f 打开Xftp并展示Xshell当前的目录,之后直接拖拽传输文件即可。 pure-ftpd搭建ftp服务 pure-ftpd要比vsftp简单,...

野雪球
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部