ホームページ > Java > &#&チュートリアル > mybatis の resultType と resultMap の違いと関連性の詳細な分析

mybatis の resultType と resultMap の違いと関連性の詳細な分析

巴扎黑
リリース: 2017-07-17 13:21:58
オリジナル
3998 人が閲覧しました

データベース接続操作に mybatis を使用する場合、SQL ステートメントによって返された結果を処理する方法は通常 2 つあります。1 つは resultType で、もう 1 つは resultMap です。以下に 2 つの知識と理解を説明します。 , 私たちが通常使用する単一テーブル クエリでは、resultType がよく使用されます

Come down and look at a one of code

 1 package org.cxxy.base.cxsc.entity; 2  3 public class TbClass { 4     private Integer id; 5  6     private String classname; 7  8     private String deptname; 9 10     public Integer getId() {11         return id;12     }13 14     public void setId(Integer id) {15         this.id = id;16     }17 18     public String getClassname() {19         return classname;20     }21 22     public void setClassname(String classname) {23         this.classname = classname == null ? null : classname.trim();24     }25 26     public String getDeptname() {27         return deptname;28     }29 30     public void setDeptname(String deptname) {31         this.deptname = deptname == null ? null : deptname.trim();32     }33 }
ログイン後にコピー

I use a small Demo of my

Come down and start post my XML Mapper

<resultMap id="BaseResultMap" type="org.cxxy.base.cxsc.entity.TbClass"><id column="id" jdbcType="INTEGER" property="id" /><result column="classname" jdbcType="VARCHAR" property="classname" /><result column="deptname" jdbcType="VARCHAR" property="deptname" /></resultMap>
ログイン後にコピー

この resultMap は、私の po クラスの属性に対応します

さあ、XML 単一テーブル クエリ ステートメントを投稿してください

<select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
ログイン後にコピー
select 
 id, classname, deptname
from tb_class
where id = #{id,jdbcType=INTEGER}
</select>
ログイン後にコピー
 <br>
ログイン後にコピー

parameterType は入力パラメータを表します (例: select * from tb_class where id = "xxxx")、resultMapマップされた結果セットを表します。これはもちろん結果セットです。もちろん、一般的な開発では、単一のテーブル クエリ (1 対 1) を表します。このようなマッピングを行う場合、通常は次のような書き方をします

<select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="类的全限定名">select 
 id, classname, deptname
from tb_class
where id = #{id,jdbcType=INTEGER}</select>
ログイン後にコピー

つまり、得られる結果は同じです。一般的に、私たちの理解では後者を選択しようとします

が、それがベースである場合は、顧客のニーズに応じて変更します。たとえば、クラスの拡張クラスを作成する

org.cxxy.base.cxsc.entity.TbClassDatail
ログイン後にコピー

拡張クラスに外部クラス(他のテーブルの属性(このクラスと共通の属性を持たない))が導入された場合、 resultMap を使用することもできますが、完全ではありません

resultMap

定义po类
在Orders类中加入User属性。
在Orders类中加入List<Orderdetail> orderdetails属性
ログイン後にコピー

Order query list

<select id="findOrdersDetailList" resultMap="userorderdetailmap">SELECT
    orders.*,
    user.username,
    user.address,
    orderdetail.id orderdetail_id,
    orderdetail.items_id,
    orderdetail.items_num
    FROM orders,user,orderdetail
    WHERE orders.user_id = user.id
    AND orders.id = orderdetail.orders_id</select> 
ログイン後にコピー

<!-- 订单信息resultmap --><resultMap type="cn.itcast.mybatis.po.Orders" id="userorderdetailmap"><id property="id"column="id"/><result property="user_id" column="user_id"/><result property="number" column="number"/><association property="user" javaType="cn.itcast.mybatis.po.User"><id property="id" column="user_id"/><result property="username" column="username"/><result property="address" column="address"/></association><collection property="orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail"><id property="id" column="orderdetail_id"/><result property="items_id" column="items_id"/><result property="items_num" column="items_num"/></collection></resultMap>
ログイン後にコピー

上記のコード、私は注文を投稿しました研修機関のクエリコード、

上記のエンティティクラス間の関係は、 Order----->User one-to-one (one user, one order) Order---------->OrderDetail 1 対多 (1 つの注文に複数の注文がある) 詳細)

このような 1 対多および多対多のクエリのマッピングでは、resultMap を使用しようとします
注:collection 标签是一对多的映射,常用于一对多中扩展类下的List<po对象>的属性
   association标签适用扩展类包含的一对一的po类对象属性
ログイン後にコピー

MyBatis における resultType と resultMap の違い

MyBatis では、選択マッピングのクエリを実行するときに、戻り値の型に resultType を使用できます。また、resultMap は戻り値の型 (モデル オブジェクトのエンティティに対応する) を直接表し、resultMap は外部への参照です。 ResultMap (db と model の間の暗黙的なキーは事前に定義されています -- > value 関係)、resultType と resultMap は同時に存在できません。

MyBatis がクエリ マッピングを実行するとき、クエリされた各属性は実際に対応する Map に配置されます。ここで、キーは属性名、値は対応する値です。

①指定された戻り値の型属性が resultType の場合、MyBatis は Map 内のキーと値のペアを取り出し、resultType で指定されたオブジェクトに対応する属性に割り当てます。したがって、実際には、MyBatis のすべてのクエリ マップの戻り値の型は ResultMap ですが、提供された戻り値の型属性が resultType の場合、MyBatis は対応する値を resultType で指定されたオブジェクトの属性に自動的に割り当てます。

②提供された戻り値の型が resultMap の場合、Map はドメイン モデルをうまく表現できないため、さらに自分で対応するオブジェクトに変換する必要があります。これは、複雑なクエリで非常に便利です。

要約すると


resultType:

Function:

SQL 列名 pojo 属性名の一貫性に従って、クエリ結果を pojo にマッピングします (単一テーブル クエリにのみ適用されます)。

機会:

ユーザーの商品購入の詳細など、いくつかの詳細なレコードを表示するのが一般的です。関連するすべてのクエリ情報がページに表示されている場合、resultType を直接使用して各レコードをポジョにマッピングできます。フロントエンド ページのリストを調べます (リストは pojo です)。

以上がmybatis の resultType と resultMap の違いと関連性の詳細な分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート