Heim  >  Artikel  >  Java  >  Beispiel-Tutorial einer MyBatis-bezogenen Abfrage

Beispiel-Tutorial einer MyBatis-bezogenen Abfrage

零下一度
零下一度Original
2017-06-25 10:34:331554Durchsuche

Bitte geben Sie die Quelle für den Nachdruck an:

In Vorbereitung: Spring+SpringMVC+MyBatis ausführliches Lernen und Konstruieren (5) – dynamisches SQL

1. Produktbestelldatenmodell

1.1 Ideen zur Datenmodellanalyse

(1) Der in jeder Tabelle aufgezeichnete Dateninhalt

Der in jeder Tabelle aufgezeichnete Inhalt ist in Module unterteilt. Vertrautheit ist gleichbedeutend mit dem Prozess des Erlernens von Systemanforderungen (Funktionen).

(2) Wichtige Feldeinstellungen für jede Tabelle

Nicht-Null-Felder, Fremdschlüsselfelder

(3) Tabellen auf Datenbankebene und Beziehungen zwischen Tabellen

Fremdschlüsselbeziehung

(4) Geschäftsbeziehung zwischen Tabellen

Bei der Analyse der Geschäftsbeziehung zwischen Tabellen muss diese auf einer bestimmten Geschäftsbedeutung basieren.

1.2 Attributmodellanalyse

2. Eins-zu-eins-Abfrage

2.1 Anforderungen

Informationen zur Abfragereihenfolge , Zuordnung Benutzerinformationen zur Abfragereihenfolge.

2.2 Methode 1: resultType

2.2.1SQL-Anweisung

Bestimmen Sie die Haupttabelle der Abfrage: Bestelltabelle

Bestimmen Sie die zugehörige Tabelle der Abfrage : Benutzertabelle

Verwendet eine verwandte Abfrage interne Links? Oder ein externer Link?

Da die Auftragstabelle einen Fremdschlüssel (user_id) enthält, kann beim Abfragen der Benutzertabelle über die Fremdschlüsselzuordnung nur ein Datensatz abgefragt werden, und es können interne Links verwendet werden.

SELECT 
  orders.*,  USER.username,  USER.sex,  USER.address 
FROM
  orders,  USER WHERE orders.user_id = user.id

2.2.2 Pojo erstellen

Ordnen Sie die Ergebnisse der obigen SQL-Abfrage dem Pojo zu, das alle Abfragespaltennamen enthalten muss.

Die ursprüngliche Orders.java kann nicht alle Felder abbilden und es muss ein neues Pojo erstellt werden.

Erstellen Sie eine Pojo-Klasse, die mehr Abfragefelder erbt.

2.2.3mapper.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"><!--namespace命名空间,作用就是对sql进行分类化的管理,理解为sql隔离
    注意:使用mapper代理开发时,namespace有特殊作用,namespace等于mapper接口地址  --><mapper namespace="joanna.yan.mybatis.mapper.OrdersCustomMapper"><!--查询订单,关联查询用户信息  --><select id="findOrdersUser" resultType="joanna.yan.mybatis.entity.OrdersCustom">SELECT 
          orders.*,
          USER.username,
          USER.sex,
          USER.address 
        FROM
          orders,
          USER 
        WHERE orders.user_id = user.id</select></mapper>

2.2.4mapper.java

public interface OrdersCustomMapper {//查询订单,关联查询用户信息public List<OrdersCustom> findOrdersUser() throws Exception;
}

2.2.5 Testprogramm

  @Testpublic void findOrdersUserTest() throws Exception{
        SqlSession sqlSession=sqlSessionFactory.openSession();
        OrdersCustomMapper ordersCustomMapper=sqlSession.getMapper(OrdersCustomMapper.class);
        List<OrdersCustom> list=ordersCustomMapper.findOrdersUser();
        System.out.println(list);
        sqlSession.close();
    }

2.3 Methode 2: resultMap

2.3.1SQL-Anweisung

implementiert mit resultType sql

2.3.2 Die Idee der Verwendung der resultMap-Zuordnung

Verwenden Sie resultMap, um die Bestellinformationen in den Abfrageergebnissen dem Orders-Objekt zuzuordnen und hinzuzufügen in der Orders-Klasse Das User-Attribut ordnet die von der Assoziation abgefragten Benutzerinformationen dem Benutzerattribut im Orders-Objekt zu.

2.3.3 Das Benutzerattribut muss zur Auftragsklasse hinzugefügt werden

2.3.4mapper.xml

2.3.4.1 Definieren resultMap

    <!--订单关联查询用户的resultMap
        将整个查询的结果映射到oanna.yan.mybatis.entity.Orders中      --><resultMap type="joanna.yan.mybatis.entity.Orders" id="OrdersUserResultMap"><!-- 1.配置映射的订单信息  --><!-- id:指定查询列中的唯一标识,订单信息中的唯一标识,如果有多个列组成唯一标识,配置多个id
             column:订单信息中的唯一标识列
             property:订单信息中的唯一标识列所映射到Orders类中的哪个属性          --><id column="id" property="id"/><result column="user_id" property="userId"/><result column="number" property="number"/><result column="createtime" property="createtime"/><result column="note" property="note"/><!-- 2.配置映射的关联的用户信息  --><!-- association:用于映射关联查询单个对象的信息
             property:要将关联查询的用户信息映射到Orders类中的哪个属性         --><association property="user" javaType="joanna.yan.mybatis.entity.User"><!-- 关联查询用户的唯一标识
                 column:指定唯一标识用户信息的列
                 property:映射到user的哪个属性              --><id column="user_id" property="id"/><result column="username" property="username"/><result column="sex" property="sex"/><result column="address" property="sex"/></association></resultMap>

2.3.4.2 Definition Anweisungsdefinition

    <!--查询订单,关联查询用户信息,使用ResultMap  --><select id="findOrdersUserResultMap" resultMap="OrdersUserResultMap">SELECT 
          orders.*,
          USER.username,
          USER.sex,
          USER.address 
        FROM
          orders,
          USER 
        WHERE orders.user_id = user.id</select>

2.3.4.3mapper.java

public interface OrdersCustomMapper {//查询订单,关联查询用户信息,使用resultMappublic List<Orders> findOrdersUserResultMap() throws Exception;
}

2.3.4.4 Testprogramm

    @Testpublic void findOrdersUserResultMapTest() throws Exception{
        SqlSession sqlSession=sqlSessionFactory.openSession();
        OrdersCustomMapper ordersCustomMapper=sqlSession.getMapper(OrdersCustomMapper.class);
        List<Orders> list=ordersCustomMapper.findOrdersUserResultMap();
        System.out.println(list);
        sqlSession.close();
    }

2.4 Zusammenfassung von resultType und resultMap zur Implementierung einer Eins-zu-Eins-Abfrage

Zu implementieren Eins-zu-Eins-Abfrage:

resultType: Es ist relativ einfach, es mit resultType zu implementieren. Wenn der abgefragte Spaltenname nicht im Pojo enthalten ist, müssen Sie das dem Spaltennamen entsprechende Attribut hinzufügen, um das zu vervollständigen Abbildung.

Wenn keine besonderen Anforderungen an Abfrageergebnisse bestehen, empfiehlt sich die Verwendung von resultType.

resultMap: Sie müssen resultMap separat definieren, was etwas mühsam zu implementieren ist. Wenn Sie besondere Anforderungen an die Abfrageergebnisse haben, können Sie resultMap verwenden, um die zugehörige Abfrage den Attributen des Pojos zuzuordnen.

resultMap kann Lazy Loading implementieren, resultType kann jedoch kein Lazy Loading implementieren.

3. Eins-zu-viele-Abfrage

3.1 Anforderungen

Informationen zur Reihenfolge und Bestelldetails abfragen

3.2 SQL-Anweisung

Bestimmen die Master-Abfragetabelle: Bestelltabelle

Bestimmen Sie die Zuordnung. Abfragetabelle: Bestelldetailtabelle

Fügen Sie einfach die Zuordnung der Bestelldetailtabelle basierend auf einer Eins-zu-eins-Abfrage hinzu.

SELECT 
  orders.*,  USER.username,  USER.sex,  USER.address,
  orderdetail.id orderdetail_id,
  orderdetail.items_id,
  orderdetail.items_num,
  orderdetail.orders_idFROM
  orders,  USER,
  orderdetailWHERE orders.user_id = user.id AND orderdetail.orders_id=orders.id

3.3 Analyse

Verwenden Sie resultType, um die obigen Abfrageergebnisse Pojo zuzuordnen, und die Bestellinformationen werden wiederholt.

Anforderungen:

Die Zuordnung von Aufträgen darf keine doppelten Datensätze enthalten.

Lösung:

Fügen Sie das List-Attribut in der Orders.java-Klasse hinzu.

Die Bestellinformationen werden schließlich Bestellungen zugeordnet, und die der Bestellung entsprechenden Bestelldetails werden dem Attribut orderDetails in Bestellungen zugeordnet.

Die Anzahl der zugeordneten Bestelldatensätze beträgt zwei (Bestellinformationen werden nicht wiederholt)

Das Attribut „orderDetails“ in jeder Bestellung speichert die Bestelldetails, die der Bestellung entsprechen.

3.4 Fügen Sie das Listenauftragsdetailattribut in der Orders-Klasse hinzu

3.5 Definieren Sie resultMap

    <!--订单及订单明细的resultMap
        使用extends继承,就不需要再配置订单信息和用户信息的映射了      --><resultMap type="joanna.yan.mybatis.entity.Orders" id="OrdersAndOrderDetailResultMap" extends="OrdersUserResultMap"><!-- 1.配置映射的订单信息  --><!-- 2.配置映射的关联的用户信息  --><!-- 使用extends继承,就不需要再配置订单信息和用户信息的映射了 --><!-- 3.配置映射的订单明细信息  --><!-- 订单明细信息
             一个订单关联查询出了多条明细,要使用collection进行映射
             collection:对关联查询到的多条记录映射到集合对象中
             property:将关联查询到多条记录映射到joanna.yan.mybatis.entity.Orders中的哪个属性
              ofType:指定映射到list集合属性中pojo的类型         --><collection property="orderdetails" ofType="joanna.yan.mybatis.entity.Orderdetail"><!-- id:订单明细的唯一标识
                 property:要讲订单明细的唯一标识映射到joanna.yan.mybatis.entity.Orderdetail的哪个属性              --><id column="orderdetail_id" property="id"/><result column="items_id" property="itemsId"/><result column="items_num" property="itemsNum"/><result column="orders_id" property="ordersId"/></collection></resultMap>

3.6 mapper.xml

    <!-- 查询订单,关联查询用户及订单明细,使用resultMap --><select id="findOrdersAndOrderDetailResultMap" resultMap="OrdersAndOrderDetailResultMap">SELECT 
          orders.*,
          USER.username,
          USER.sex,
          USER.address,
          orderdetail.id orderdetail_id,
          orderdetail.items_id,
          orderdetail.items_num,
          orderdetail.orders_id
        FROM
          orders,
          USER,
          orderdetail
        WHERE orders.user_id = user.id AND orderdetail.orders_id=orders.id</select>

3.7mapper.java

public interface OrdersCustomMapper {//查询订单,关联查询用户信息public List<OrdersCustom> findOrdersUser() throws Exception;//查询订单,关联查询用户信息,使用resultMappublic List<Orders> findOrdersUserResultMap() throws Exception;//查询订单(关联用户)及订单明细public List<Orders> findOrdersAndOrderDetailResultMap() throws Exception;
}

3.8 Testprogramm

    @Testpublic void findOrdersAndOrderDetailResultMapTest() throws Exception{
        SqlSession sqlSession=sqlSessionFactory.openSession();
        OrdersCustomMapper ordersCustomMapper=sqlSession.getMapper(OrdersCustomMapper.class);
        List<Orders> list=ordersCustomMapper.findOrdersAndOrderDetailResultMap();
        System.out.println(list);
        sqlSession.close();
    }

3.9小结

mybatis使用resultMap的collection对关联查询的多条记录映射到有个list集合属性中。

使用resultType实现:

将订单明细映射到orders中的orderdetails中,需要自己处理,使用双重循环遍历,去掉重复记录,将订单明细放在ordertails中。

4.多对多查询

4.1需求

查询用户及用户购买的商品信息。

4.2sql语句

查询主表:用户表

关联表:由于用户和商品没有直接关联,通过订单和订单明细进行关联,所有关联表:orders、orderdetail、items。

SELECT 
  orders.*,  USER.username,  USER.sex,  USER.address,
  orderdetail.id orderdetail_id,
  orderdetail.items_id,
  orderdetail.items_num,
  orderdetail.orders_id,
  items.name items_name,
  items.detail items_detail,
  items.price items_priceFROM
  orders,  USER,
  orderdetail,
  itemsWHERE orders.user_id = user.id AND orderdetail.orders_id=orders.id AND orderdetail.items_id = items.id

4.3映射思路

将用户信息映射到user中。

在User类中添加订单列表属性List orderslist,将用户创建的订单映射到orderslist;

在Orders中田间订单明细列表属性List orderdetails,将订单的明细映射到orderdetails;

在OrderDetail中添加Items属性,将订单明细所对应的商品映射到Items。

4.4 mapper.xml

    <select id="findUserAndItemsResultMap" resultMap="UserAndItemsResultMap">SELECT 
          orders.*,
          USER.username,
          USER.sex,
          USER.address,
          orderdetail.id orderdetail_id,
          orderdetail.items_id,
          orderdetail.items_num,
          orderdetail.orders_id,
          items.name items_name,
          items.detail items_detail,
          items.price items_price
        FROM
          orders,
          USER,
          orderdetail,
          items
        WHERE orders.user_id = user.id AND orderdetail.orders_id=orders.id AND orderdetail.items_id = items.id        </select>

4.5定义resultMap

    <!-- 查询用户及购买商品  --><resultMap type="joanna.yan.mybatis.entity.User" id="UserAndItemsResultMap"><!-- 1.用户信息 --><id column="user_id" property="id"/><result column="username" property="username"/><result column="sex" property="sex"/><result column="address" property="address"/><!-- 2.订单信息 --><!-- 一个用户对应多个订单,使用collection映射 --><collection property="ordersList" ofType="joanna.yan.mybatis.entity.Orders"><id column="id" property="id"/><result column="user_id" property="userId"/><result column="number" property="number"/><result column="createtime" property="createtime"/><result column="note" property="note"/><!-- 3.订单明细  --><!-- 一个订单包括多个明细 --><collection property="orderdetails" ofType="joanna.yan.mybatis.entity.Orderdetail"><id column="orderdetail_id" property="id"/><result column="items_id" property="itemsId"/><result column="items_num" property="itemsNum"/><result column="orders_id" property="ordersId"/><!-- 4.商品信息  --><!-- 一个订单明细对应一个商品 --><association property="items" javaType="joanna.yan.mybatis.entity.Items"><id column="items_id" property="id"/><result column="items_name" property="name"/><result column="items_detail" property="detail"/><result column="items_price" property="price"/></association></collection></collection></resultMap>

4.6mapper.java

public interface OrdersCustomMapper {//查询订单,关联查询用户信息public List<OrdersCustom> findOrdersUser() throws Exception;//查询订单,关联查询用户信息,使用resultMappublic List<Orders> findOrdersUserResultMap() throws Exception;//查询订单(关联用户)及订单明细public List<Orders> findOrdersAndOrderDetailResultMap() throws Exception;//查询用户购买商品信息public List<User> findUserAndItemsResultMap() throws Exception;
}

4.7测试程序

    @Testpublic void findUserAndItemsResultMapTest() throws Exception{
        SqlSession sqlSession=sqlSessionFactory.openSession();
        OrdersCustomMapper ordersCustomMapper=sqlSession.getMapper(OrdersCustomMapper.class);
        List<User> list=ordersCustomMapper.findUserAndItemsResultMap();
        System.out.println(list);
        sqlSession.close();
    }

4.8多对多查询总结

将查询用户购买的商品信息明细清单(用户名、用户地址、购买商品名称、购买商品时间、购买商品数量)

针对上面的需求就使用resultType将查询到的记录映射到一个扩展的pojo中,很简单实现明细清单的功能。

一对多是多对多的特例,如下需求:

查询用户购买的商品信息,用户和商品的关系是多对多关系。

需求1:

查询字段:用户账号、用户名称、用户性别、商品名称、商品价格(最常见)

企业开发中常见明细列表,用户购买商品明细列表,

使用resultType将上边查询列映射到pojo输出。

需求2:

查询字段:用户账号、用户名称、购买商品数量、商品明细(鼠标移上显示明细)

使用resultMap将用户购买的商品明细列表映射到user对象中。

总结:

使用resultMap是针对那些对查询结果映射有特殊要求的功能,比如特殊要求映射成list中包含多个list。

 5.resultMap总结

resultType:

作用:将查询结果按照sql列名pojo属性一致性映射到pojo中。

场合:

  常见一些明细记录的展示,比如用户购买商品明细,将关联查询信息全部展示在页面时,此时可直接使用resultType将每一条记录映射到pojo中,在前端页面遍历list(list中是pojo)即可。

resultMap:

  使用association和collection完成一对一和一对多高级映射(对结果又特殊的映射要求)。

association:

作用:将关联查询信息映射到一个pojo对象中。

场合:

为了方便查询关联信息可以使用association将关联订单信息映射为用户对象的pojo属性中,比如:查询订单及关联用户信息。

  使用resultType无法将查询结果映射到pojo对象的pojo属性中,根据对结果集查询遍历的需要选择使用resultType还是resultMap。

collection:

作用:将关联查询信息映射到一个list集合中。

场合:为了方便擦还行遍历关联信息可以使用collection将关联信息映射到list集合中,比如:查询用户权限范围模块及模块下的菜单,可使用collection将模块映射到模块list中,将菜单列表映射到模块对象的菜单list属性中,这样做册目的也是方便对查询结果集进行遍历查询。

  如果使用resultType无法将查询结果映射到list集合中。 

Das obige ist der detaillierte Inhalt vonBeispiel-Tutorial einer MyBatis-bezogenen Abfrage. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn