MyBatis的association示例——MyBatis学习笔记之三

前两篇博文介绍的都是单表映射,而实际上很多时候我们需要用到较复杂的映射。今天学会的association的用法,就是一例,现写出来和大家分享(为简洁起见,ant工程中各文件、目录的布局,香港空间,以及其它与前面的例子重复的内容,将不再赘述。以后博文亦将如此)。

假设每个学生都有一名指导老师,本示例的任务就是查询出学生的详细信息,这就包括学生的指导教师的信息。为此,应先增加一个教师的实体类。如下所示(和以前一样的原因,读者不要复制本文的配置文件。在文章下方的附件下载处,服务器空间,可下载本示例的完整代码):

相应地,在数据库中,应增加教师表。完成此任务的脚本(teacher.sql)如下:

在命令行下以courseman身份登录MySQL(mysql–ucourseman–pabc123),用source命令运行此脚本(若teacher.sql放在D盘,香港服务器租用,即d:\teacher.sql,则运行命令sourced:/teacher.sql。注意,这里是“/”,而不是“\”。以下脚本的运行方式不再赘述)。

接着为学生增加指导教师属性,如下:

在MyBatis的核心配置文件configuration.xml中增加教师类型的别名定义,如下:

然后,我们需要修改StudentMapper.xml中的select语句及要用到的resultMap元素,这是本示例的关键部分。

首先,为了能够同时查询到学生的指导教师的信息,修改select语句如下:

为了实现查询结果与实体的映射,需要修改resultMap元素。此时的学生实体拥有一个指导教师属性(supervisor),而该属性本身就是一个实体。这是一种has-a关系,亦即一个学生有一个指导教师,而association元素就是处理这种关系的映射的。我们为resultMap添加association如下(从第12行开始):

其中的javaType属性为必须,否则报以下错误:

这次的执行类是AssociationDemo,代码如下:

相应地,应修改ant的生成文件build.xml中的runtarget,指定这个类是要运行的类:

执行结果如下:

【MyBatis学习笔记】系列之预备篇一:ant的下载与安装

【MyBatis学习笔记】系列之预备篇二:ant入门示例

【MyBatis学习笔记】系列之一:MyBatis入门示例

【MyBatis学习笔记】系列之二:MyBatis增删改示例

【MyBatis学习笔记】系列之三:MyBatis的association示例

【MyBatis学习笔记】系列之四:MyBatisassociation的两种形式

【MyBatis学习笔记】系列之五:MyBatis与Spring集成示例

【MyBatis学习笔记】系列之六:MyBatis与Spring集成示例续

【MyBatis学习笔记】系列之七:MyBatis一对多双向关联

【MyBatis学习笔记】系列之八:MyBatisMapperScannerConfigurer配置

【MyBatis学习笔记】系列之九:MyBatiscollection的两种形式

【MyBatis学习笔记】系列之十:MyBatis日志之Log4j示例

【MyBatis学习笔记】系列之十一:MyBatis多参数传递之注解方式示例

【MyBatis学习笔记】系列之十二:MyBatis多参数传递之默认命名方式示例

【MyBatis学习笔记】系列之十三:MyBatis多参数传递之Map方式示例

【MyBatis学习笔记】系列之十四:MyBatis中的N+1问题

【MyBatis学习笔记】系列之十五:MyBatis多参数传递之混合方式

【MyBatis学习笔记】系列之十六:Spring声明式事务管理示例

【MyBatis学习笔记】系列之十七:MyBatis多对多保存示例

本文出自 “肖凡的专栏” 博客,请务必保留此出处

还有不愿面对失败的尴尬。曾经怀有远大理想,拥有完美的憧憬。

MyBatis的association示例——MyBatis学习笔记之三

相关文章:

你感兴趣的文章:

标签云: