ホームページ  >  記事  >  Java  >  mybatis の resultType と resultMap の違いと関連性の詳細な分析

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

巴扎黑
巴扎黑オリジナル
2017-07-17 13:21:583927ブラウズ

データベース接続操作に 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

2fcf37cc8639c0835f2a112fe5f93a849eef2c25b88ca2d81d394f11ec96c407e7278c69b1e0021e9427bf255a0086f7bb49b36718ffba6c40aa7d011fafcc356ebaf93ccf0a7eb73abf17f5d66f496d

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

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

669abfcbe0c33fe8796fe4e80dcc38da
select 
 id, classname, deptname
from tb_class
where id = #{id,jdbcType=INTEGER}
18bb6ffaf0152bbe49cd8a3620346341
 <br>

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

a2aa3edd282ebb7d674f208ca16e6482select 
 id, classname, deptname
from tb_class
where id = #{id,jdbcType=INTEGER}18bb6ffaf0152bbe49cd8a3620346341

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

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

org.cxxy.base.cxsc.entity.TbClassDatail

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

resultMap

定义po类
在Orders类中加入User属性。
在Orders类中加入List<Orderdetail> orderdetails属性

Order query list

67b7af552f22717e0a27bb8ca8afddafSELECT
    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_id18bb6ffaf0152bbe49cd8a3620346341 
5357cb75350360434e7a14c60a460937

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

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

このような 1 対多および多対多のクエリのマッピングでは、resultMap を使用しようとします
注:collection 标签是一对多的映射,常用于一对多中扩展类下的List26f8748aa4657b998cc4ad34c80d1a5b的属性
   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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。