今天学会的association的用法,就是一例,现写出来和大家分享(为简洁起见,ant工程中各文件、目录的布局,以及其它与前面的例子重复的内容,将不再赘述。以后博文亦将如此)。

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

package com.abc.domain;
public class Teacher{
private int id;
private String name;  //姓名
private String gender;//性别
private String researchArea;//研究方向
private String title;//职称
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 getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
public String getResearchArea() {
return researchArea;
}
public void setResearchArea(String researchArea) {
this.researchArea = researchArea;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
}

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

/*数据库编码UTF8,以下命令是为了在脚本和
命令行中支持中文*/
set names gbk;
/*切换到courseman数据库*/
use courseman;
/*创建成绩表*/
drop table if exists teacher;
CREATE TABLE teacher(
id int NOT NULL AUTO_INCREMENT primarykey,
name varchar(10) NOT NULL,/*姓名*/
gender char(1) NOT NULL,/*性别*/
research_area varchar(20) NOT NULL,/*研究方向*/
title varchar(6) NOT NULL/*职称*/
);
/*添加第一条记录,自动生成的ID为1*/
insert into teacher(name,gender,research_area, title)
values('张伟','男','软件工程','讲师');

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

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

private Teacher supervisor; //指导教师

并为此属性编写getter和setter方法,此处略去。

相应地,为学生表增加一个指导教师ID的字段,脚本(supervisor.sql)如下:

/*切换到courseman数据库*/
use courseman;
/*为学生表添加指导老师ID列*/
alter TABLE student add supervisor_id int not null
references teacher(id);
/*把上面新增的教师作为目前学生的指导教师*/
update student set supervisor_id=1;

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

<typeAliases>
<typeAlias alias="Student" type="com.abc.domain.Student"/>
<!--增加的教师类型别名-->
<typeAlias alias="Teacher" type="com.abc.domain.Teacher"/>
</typeAliases>

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

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

<select id="getById" parameterType="int" resultMap="studentResultMap">
select st.id,st.name,st.gender,
st.major,st.grade,
<!--为教师的id取别名,避免MyBatis向教师实体注入
此属性时与学生id混淆。以下的name和gender等属性
也是如此-->
t.id t_id,t.name t_name,t.gender t_gender,
t.title,t.research_area
from student st, teacher t
where st.supervisor_id = t.id
and st.id=#{id}
</select>

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

<resultMap id="studentResultMap" type="Student">
<!--普通属性映射与以前一致-->
<id property="id" column="id"/>
<result property="name" column="name"/>
<result property="gender" column="gender"/>
<result property="major"  column="major"/>
<result property="grade"  column="grade"/>
<!--property="supervisor"表明这是为了映射学生实体的
supervisor属性。javaType="Teacher"用到了Teacher这个
别名定义,并指出了supervisor属性的java类型-->
<association property="supervisor" javaType="Teacher">
<!--教师自身的属性与数据库字段的映射。注意这里用到了字段别名--><id property="id" column="t_id"/><result property="name" column="t_name"/><result property="gender" column="t_gender"/><result property="researchArea" column="research_area"/><result property="title" column="title"/>
</association>
</resultMap>

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

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

package com.demo;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSession;
import com.abc.mapper.StudentMapper;
import com.abc.domain.Student;
import com.util.SqlSessionFactoryGen;
public class AssociationDemo
{
//获取SqlSessionFactory实例
private static SqlSessionFactory factory
= SqlSessionFactoryGen.getSqlSessionFactory();
public static void main(String[] args)
{
SqlSession session = factory.openSession();
StudentMapper mapper =
session.getMapper(StudentMapper.class);
//笔者的数据库中只有ID为4的学生。读者若运行此程序,
//须使用你的数据库中存在的学生ID。否则报空指针异常
Student student = mapper.getById(4);
//使用StringBuilder的append操作代替字符串的“+”
//操作可提高执行效率
StringBuilder sb = new StringBuilder("学生信息:\n");
sb.append("姓名:");
sb.append(student.getName());
sb.append(" ");
sb.append( "专业:");
sb.append(student.getMajor());
sb.append(" 年级:");
sb.append(student.getGrade());
sb.append("\n");
sb.append("指导教师信息:\n");
sb.append("姓名:");
sb.append(student.getSupervisor().getName());
sb.append(" ");
sb.append("职称:");
sb.append(student.getSupervisor().getTitle());
sb.append(" ");
sb.append("研究方向:");
sb.append(student.getSupervisor().getResearchArea());
System.out.println(sb.toString());
session.close();
}
}

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

<target name="run" depends="compile">
<!--指定AssociationDemo为要运行的类-->
<java fork="true" classname="com.demo.AssociationDemo" classpathref="library"><classpath path="${targetdir}"/>
</java>
</target>

执行结果如下:

MyBatis的association示例相关推荐

  1. mybatis中association 和collection 的区别

    mybatis中association 和collection 的区别:https://zhidao.baidu.com/question/1240407172484106299.html 两个实体类 ...

  2. Mybatis | Mybatis标签association一对一的使用

    Mybatis标签association一对一的使用 一.association 二.使用方法 1. 方法一: 嵌套结果映射 2. 方法二: 嵌套select 查询 三.colleciton 一对多 ...

  3. mysql association_MyBatis的association示例——MyBatis学习笔记之三

    前两篇博文介绍的都是单表映射,而实际上很多时候我们需要用到较复杂的映射.今天学会的association的用法,就是一例,现写出来和大家分享(为简洁起见,ant工程中各文件.目录的布局,以及其它与前面 ...

  4. MyBatis增删改示例——MyBatis学习笔记之二

    上篇博文介绍了MyBatis的一个入门示例,今天介绍如何实现数据库的增加.删除和修改记录的操作.为简洁起见,与上个示例重复的注释将被删除(少数重要的除外).若影响了您的理解,可参考上篇博文. 本示例的 ...

  5. 【Mybatis框架】从零开始学Mybatis框架——使用示例

    一.数据库SQL 命令 1.创建数据库,并指定编码 Create database ssm default character set utf8 2.创建表 Create table 表名(列名类型约 ...

  6. mybatis的association以及collection的用法

    在项目中,某些实体类之间肯定有关键关系,比如一对一,一对多等.mybatis 中就用association和collection. association: 一对一关联(has one) collec ...

  7. Mybatis学习 association关联 和 collection集合

    MySQL中的多对一.一对多关系 · 多对一 如老师和学生,很多个学生由一个老师教,这个时候就是多对一关系. 可以定义学生和老师实体类如下: @Data public class Student {p ...

  8. MyBatis之association嵌套

    表.实体类.myBatisConfig.xml文件.以及测试类请看MyBatis之一对一关联 ,没必要再复制一遍这些内容 嵌套resultMap: [html] view plaincopy < ...

  9. mybatis中association的使用

    association通常用来映射一对一的关系 示例: <resultMap type="com.ddwl.api.entity.xxx" id="resultIt ...

最新文章

  1. 两个rtsp同时抓流_海康摄像头同时添加到两台海康硬盘录像机上
  2. 创建试图 失败_导致微服务失败的 11 个原因
  3. MySQL:缓存算什么东西?!
  4. 旅游系统_旅游景区安全标识系统设计原则
  5. 管理mysql表知识点_数据库复习提纲(必考知识点整理)
  6. 区块链中的数学 - EdDSA签名机制
  7. python中multiple函数_关于多处理:在Python中将多个参数传递给pool.map()函数
  8. linux rm 某个时间以前,(转)linux的一个find命令配合rm删除某天前的文件
  9. 安装VS2008错误解决
  10. python生成字符画_通过python将图片生成字符画
  11. 【BZOJ】1303: [CQOI2009]中位数图(特殊的技巧)
  12. 【Windows IoT】usb 票据打印机打印(未完成)
  13. ecg 幅度_心电图(ECG或EKG)设计原理及实例应用
  14. 印象笔记如何分享链接_印象笔记共享问题解决经过
  15. DirectX 基础总结笔记
  16. Python条件判断
  17. 一起学JAVA之【基础篇】4种默认线程池介绍
  18. 上课案列-翻牌游戏(重置、历史记录)
  19. matlab trapz二重积分函数_如何使用 MATLAB 求解定积分、不定积分和多重积分问题...
  20. 【论文精读】A Survey on Deep Learning for Named Entity Recognition

热门文章

  1. 汇编浮点指令fld、fstp
  2. Zookeeper 安装和配置---学习一
  3. 排序算法——插入排序
  4. ADO学习(九)如何阅读ADO文档
  5. 高性能、低成本的高防 IP 产品能现实吗?
  6. 如何替公司省下数千万勒索费用
  7. Redis 缓存常见问题 :缓存雪崩,缓存击穿,缓存穿透,缓存预热
  8. 阿里巴巴工程师:Java 编程技巧之数据结构
  9. 原来这样调优可以攻破MySQL性能瓶颈
  10. 李郁韬:短期爆发还是未来趋势?腾讯云海量音视频通信服务背后的技术发展