データベース接続操作に 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
<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 クラスの属性に対応します
<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 つの注文に複数の注文がある) 詳細)
注: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 サイトの他の関連記事を参照してください。