データベース接続操作に 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></id><result></result><result></result></resultmap>
この resultMap は、私の po クラスの属性に対応します
<select></select>
select id, classname, deptname from tb_class where id = #{id,jdbcType=INTEGER}
<br>
parameterType は入力パラメータを表します (例: select * from tb_class where id = "xxxx")、resultMapマップされた結果セットを表します。これはもちろん結果セットです。もちろん、一般的な開発では、単一のテーブル クエリ (1 対 1) を表します。このようなマッピングを行う場合、通常は次のような書き方をします
<select>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>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><id></id><result></result><result></result><association><id></id><result></result><result></result></association><collection><id></id><result></result><result></result></collection></resultmap>
上記のエンティティクラス間の関係は、 Order----->User one-to-one (one user, one order) Order---------->OrderDetail 1 対多 (1 つの注文に複数の注文がある) 詳細)
注:collection 标签是一对多的映射,常用于一对多中扩展类下的List<po>的属性 association标签适用扩展类包含的一对一的po类对象属性</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 サイトの他の関連記事を参照してください。

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

Dreamweaver Mac版
ビジュアル Web 開発ツール
