MyBitis(iBitis)系列随笔之一:MyBitis入门实例

MyBitis(iBitis)系列随笔之二:类型别名(typeAliases)与表-对象映射(ORM)

MyBitis(iBitis)系列随笔之三:简单实现CRUD

MyBitis(iBitis)系列随笔之四:多表(多对一查询操作)

MyBitis(iBitis)系列随笔之五:多表(一对多关联查询)

MyBitis(iBitis)系列随笔之六:mybitis与spring集成

这篇博文介绍的是多表中的一对多表关联查询
还是按照上一篇的步骤,先做一些准备工作;创建两张表:一张是用户,一张是用户所对应的移动手机,一户用户可以有部移动手机。
      这是用户t_user表


        这是移动电话t_mobile表
              
           在Java实体对象对中,一对多可以根据List和Set来实现,两者在mybitis中都是通过collection标签来配合使用,稍后会做详细配置介绍

创建表对应的JavaBean对象

Mobile  Bean

  1. public class Mobile {
  2. private int id;
  3. private String telnumber;
  4. public int getId() {
  5. return id;
  6. }
  7. public void setId(int id) {
  8. this.id = id;
  9. }
  10. public String getTelnumber() {
  11. return telnumber;
  12. }
  13. public void setTelnumber(String telnumber) {
  14. this.telnumber = telnumber;
  15. }
  16. }

User Bean

  1. package com.jefry;
  2. import java.util.List;
  3. public class User {
  4. private int id;
  5. private String userName;
  6. private String password;
  7. private List<Mobile> mobiles; //这里也可以是Set集合
  8. public List<Mobile> getMobiles() {
  9. return mobiles;
  10. }
  11. public void setMobiles(List<Mobile> mobiles) {
  12. this.mobiles = mobiles;
  13. }
  14. public String getUserName() {
  15. return userName;
  16. }
  17. public void setUserName(String userName) {
  18. this.userName = userName;
  19. }
  20. public String getPassword() {
  21. return password;
  22. }
  23. public void setPassword(String password) {
  24. this.password = password;
  25. }
  26. public int getId() {
  27. return id;
  28. }
  29. public void setId(int id) {
  30. this.id = id;
  31. }
  32. }

在上一篇的基础上改写映射文件:

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="user">
  6. <resultMap id="userResultMap" type="User">
  7. <id property="id" column="id" javaType="int" jdbcType="INTEGER" />
  8. <result property="userName" column="name" javaType="string" jdbcType="VARCHAR"/>
  9. <result property="password" column="pass" javaType="string" jdbcType="VARCHAR"/>
  10. <collection property="mobiles" column="userid" ofType="Mobile">
  11. <id property="id" column="id" javaType="int" jdbcType="INTEGER"/>
  12. <result property="telnumber" column="telnumber" javaType="string" jdbcType="VARCHAR"/>
  13. </collection>
  14. </resultMap>
  15. <!--多表查询操作-->
  16. <select id="selectUser" parameterType="int"  resultMap="userResultMap" >
  17. <!--分别为mobile的主键id与user的主键id赋值别名,避免因为两个表字段名称相同而注入到对应对象名称冲突-->
  18. select m.id m_id,m.telnumber,u.id u_id,u.name,u.pass from t_mobile m,t_user u where m.userid = u.id and u.id = #{id}
  19. </select>
  20. </mapper>

最后,通过测试OK

  1. public class Test {
  2. static String resource = "mybatis-config.xml";
  3. public static void main(String[] args) throws IOException {
  4. InputStream inputStream = Resources.getResourceAsStream(resource);
  5. SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  6. SqlSession session = sqlSessionFactory.openSession();
  7. try {
  8. User user = session.selectOne("user.selectUser", 1);
  9. List<Mobile> mobiles = user.getMobiles();
  10. for(Mobile mobile : mobiles) {
  11. System.out.println("user:" + user.getUserName() + ",tel:" + mobile.getTelnumber());
  12. }
  13. } finally {
  14. session.close();
  15. }
  16. }
  17. }

源码下载:http://download.csdn.net/detail/jefry_xdz/5229451

http://blog.csdn.net/jefry_xdz/article/details/8767358

http://www.cnblogs.com/yinkh/p/5564033.html

最新文章

  1. 首席技术官 (CTO) 比普通程序员强在哪
  2. Java 使用对话框选择文件并输出到控制台
  3. 使用.9.png报错 Exception raised during rendering
  4. ren
  5. Nginx学习之十一-Nginx启动框架处理流程
  6. Java内部类总结
  7. jq实现图像旋转木马:轮焦点+关于控制+自己主动旋转木马
  8. ADS协议变量配置界面
  9. SSRF
  10. spring的webutils包。适用于访问httpservletrequest和httpservletresponse
  11. C++中模板的使用
  12. wpf让图片自适应容器大小,而且又不会拉升变形
  13. arcgis api for js 之发布要素服务
  14. 正则表达式——WPF输入控件TextBox 限定输入特定字符
  15. 进程实时监控pidstat命令详解
  16. Eclipse Oxygen创建maven web项目(一)
  17. Android的线程使用来更新UI----Thread、Handler、Looper、TimerTask等
  18. 伪共享(False Sharing)
  19. Linux ss命令详解
  20. MATLAB复制图片时边框大的问题

热门文章

  1. Nhibernate 映射关系,一对多 多对一与多对手在映射文件中的体现。
  2. Android Bitmaps缓存
  3. Android 大神博客汇集
  4. Apache-Tomcat 和 Apache-Maven配置
  5. php or || 和 and &amp;&amp;
  6. python基础笔记-0
  7. QTcpSocket 及 TCP粘包分析
  8. C++ typeid实现原理
  9. mysql utf8 中文
  10. jdk7和8的一些新特性介绍