#千锋逆战# Mybatis多表联合

Mybatis多表联合查找

  1. 加入依赖

    • 加入mybatis核心依赖,junit测试,mysql依赖

    • <dependencies>
          <dependency>
              <groupId>junit</groupId>
              <artifactId>junit</artifactId>
              <version>4.12</version>
          </dependency>
      
          <dependency>
              <groupId>mysql</groupId>
              <artifactId>mysql-connector-java</artifactId>
              <version>5.1.47</version>
          </dependency>
      
          <dependency>
              <groupId>org.mybatis</groupId>
              <artifactId>mybatis</artifactId>
              <version>3.4.6</version>
          </dependency>
      
  2. XML配置

    • resources目录下新建Mybatis.xml文件

    • 导入db.properties资源文件,如下

      driver=com.mysql.jdbc.Driver
      url=jdbc:mysql://localhost:3307/shop_mybatis
      username=root
      password=970809
      
    • 设置settings,加入自动日志

    • 设置typeAliases,设置别名包,此包下的引用可直接写类名,忽略大小写

    • 设置连接池属性POOLED

    • 在mappers标签下设置对应的映射文件路径

    • <?xml version="1.0" encoding="UTF-8" ?>
      <!DOCTYPE configuration
              PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
              "http://mybatis.org/dtd/mybatis-3-config.dtd">
      <configuration>
          <properties resource="db.properties"/>
      
          <!--添加日志功能,STDOUT_LOGGING不需要添加第三方jar包-->
          <settings>
              <setting name="logImpl" value="STDOUT_LOGGING"/>
          </settings>
          <typeAliases>
              <package name="pojo"/>
          </typeAliases>
      
          <environments default="development">
              <environment id="development">
                  <transactionManager type="JDBC"/>
                  <dataSource type="POOLED">
                      <property name="driver" value="${driver}"/>
                      <property name="url" value="${url}"/>
                      <property name="username" value="${username}"/>
                      <property name="password" value="${password}"/>
                  </dataSource>
              </environment>
          </environments>
      
          
          <mappers>
              <mapper resource="com/mapper/OrderMapper.xml"/>
              <mapper resource="com/mapper/UserMapper.xml"/>
              <mapper resource="com/mapper/DetailMapper.xml"/>
              <mapper resource="com/mapper/ProductMapper.xml"/>
              <mapper resource="com/mapper/TypeMapper.xml"/>
          </mappers>
      </configuration>
      
  3. OrderMapper.xml配置例举

    • namespace和id组合唯一,可自定义

    • 使用select标签进行查询操作,其他操作分别为update,insert,delete

    • 使用resultMap进行联合查询

    • resultMap标签下 如果对应pojo内的属性名(property)和数据库表中的列名相同,可省略不写result标签

    • 使用association标签进行对一的表结构联合查询,使用Collection标签进行对多的表结构联合查询

    • <?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="pojo.OrderMapper">
          <select id="getOrderByOid" resultMap="orderMap">
              select * from orders where oid = #{oid}
        </select>
          
          <resultMap id="orderMap" type="Order">
      <!--        <id property="oid" column="oid"/>-->
      <!--        <result column="price" property="price"/>-->
      <!--        <result column="addr" property="addr"/>-->
      <!--        <result column="payType" property="payType"/>-->
      
              <!--对一,select中填写对应的映射文件的namespace.id-->
              <association property="user" column="uid" select="pojo.UserMapper.getUserByUid"/>
      
             <!--对多-->
              <collection property="details" column="did" select="pojo.DetailMapper.getDetailByDid" ofType="pojo.Detail"/>
          </resultMap>
      </mapper>
      
  4. UserMapper.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="pojo.UserMapper">
          <select id="getUserByUid" resultType="User">
          select * from users where uid = #{uid}
        </select>
      
      </mapper>
      
  5. DetailMapper.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="pojo.DetailMapper">
          <select id="getDetailByDid" resultMap="detailMap">
              select * from details where did = #{did}
        </select>
      
      
          <resultMap id="detailMap" type="Detail">
      <!--        <id property="did" column="did"/>-->
      <!--        <result column="count" property="count"/>-->
      
              <association property="product" column="pid" select="pojo.ProductMapper.getProductByPid"/>
          </resultMap>
      
      </mapper>
      
  6. ProductMapper.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="pojo.ProductMapper">
          <select id="getProductByPid" resultMap="productMap">
          select * from products where pid = #{pid}
        </select>
      
          <resultMap id="productMap" type="Product">
      
      <!--        <id property="pid" column="pid"/>-->
      <!--        <result property="name" column="name"/>-->
      <!--        <result property="price" column="price"/>-->
      <!--        <result property="img" column="img"/>-->
      
              <association property="type" column="tid" select="pojo.TypeMapper.getTypeByTid"/>
          </resultMap>
      
      </mapper>
      
  7. TypeMapper.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="pojo.TypeMapper">
          <select id="getTypeByTid" resultType="Type">
          select * from types where tid = #{tid}
        </select>
      
      </mapper>
      
  8. 测试类

    • 使用junit的@Before注解,setUp在所有方法运行前运行

    • import org.apache.ibatis.io.Resources;
      import org.apache.ibatis.session.SqlSession;
      import org.apache.ibatis.session.SqlSessionFactory;
      import org.apache.ibatis.session.SqlSessionFactoryBuilder;
      import org.junit.After;
      import org.junit.Before;
      import org.junit.Test;
      import pojo.Order;
      
      import java.io.IOException;
      
      public class TestOrders {
          private SqlSessionFactory sf = null;
          private SqlSession session = null;
      
          @Before
          public void setUp() {
              try {
                  sf = new SqlSessionFactoryBuilder().build(Resources.getResourceAsStream("Mybatis.xml"));
                  session = sf.openSession();
              } catch (IOException e) {
                  e.printStackTrace();
              }
          }
      
          @After
          public void tearDown() {
              if (session != null) {
                  session.close();
                  session = null;
              }
          }
      
          @Test
          public void testGetOrderByOid() {
              Order order = session.selectOne("pojo.OrderMapper.getOrderByOid",1);
              System.out.println(order);
          }
      }
      
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容

  • 在学习MyBatis3的过程中,文档上面一直在强调一个id的东西!在做这个实验的时候,也因为没有理解清楚id含义而...
    杀小贼阅读 980评论 0 6
  • 一、配置maven的pom.xml加载jar包 为了后续开发的方便,将SSM框架所有需要的jar包一并加载进来 p...
    docki阅读 2,244评论 1 23
  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,461评论 0 4
  • 一、结果映射是什么? ResultMap 1.使用场景一 当数据库的列名和实体类的属性名不一致时,无法直接通过re...
    huishao阅读 1,035评论 3 3
  • 1、Mybatis支持普通SQL查询、存储一级高级映射的优秀持久层框架 2、Mybatis可以使用简单的XML或注...
    JHMichael阅读 349评论 0 1