4.2 Java EE - 1対1のクエリ

<association>要素 

 

実生活では、1 対 1 の関係が非常に一般的です。たとえば、ID カードは 1 人につき 1 枚しか持てず、ID カードは 1 人にのみ対応します。人とIDカードの関係は図のようになります。

        MyBatis では、1 対 1 の関係は <association> 要素を通じて処理されます。<association> 要素は、データ テーブル間の関係を維持するための一連の属性を提供します。

<association> 要素の属性

属性

説明する

財産

マッピング先のエンティティクラスオブジェクトの属性を、テーブルフィールドに一つずつ対応させて指定するために使用されます。

テーブル内の対応するフィールドを指定するために使用されます

javaタイプ

エンティティ オブジェクトにマップされるプロパティのタイプを指定するために使用されます。

jdbcタイプ

データテーブル内の対応するフィールドのタイプを指定するために使用されます。

フェッチタイプ

クエリをリンクするときに遅延読み込みを有効にするかどうかを指定するために使用されます。fetchType属性にはlazyとeagerの2つの属性値があり、デフォルト値はlazyです

選択する

ネストされたクエリを導入するサブ SQL ステートメントを指定するために使用されます。

自動マッピング

自動的にマッピングするかどうかを指定するために使用されます

タイプハンドラー

型ハンドラーを指定するために使用されます

<association> 要素の構成方法

        <association> 要素は <resultMap> 要素のサブ要素であり、ネストされたクエリ メソッドとネストされた結果メソッドの 2 つの設定方法があり、それぞれ次の 2 つの設定方法が導入されています。

a. ネストされたクエリメソッド

        ネストされたクエリとは、別の SQL マッピング ステートメントを実行して、予期される複合型を返すことを指します。

<association property="card" column="card_id" 

javaType="com.mac.pojo.IdCard"   
select="com.itheima.mapper.IdCardMapper.findCodeById" />

b. ネストされた結果メソッド

        ネストされた結果は、ネストされた結果マップを使用して重複を処理するユニオン結果のサブセットです。

<association property="card" javaType="com.mac.pojo.IdCard">

    <id property="id" column="card_id" />

    <result property="code" column="code" />

</association>

        次に、個人とIDカードの1対1関係を例に、MyBatisにおける1対1関係の処理を詳しく説明します。事例の具体的な実装手順は以下の通りです。

1. データテーブルの作成: mybatis データベースに tb_idcard という名前の ID カード データ テーブルと tb_person という名前の個人データ テーブルを作成し、事前にいくつかのデータを挿入します。 

USE mybatis;

# 创建一个名称为tb_idcard的表

CREATE TABLE  tb_idcard( 

     id INT PRIMARY KEY AUTO_INCREMENT,

     CODE VARCHAR(18) );

# 插入2条数据

INSERT INTO tb_idcard(CODE) VALUES('152221198711020624');

INSERT INTO tb_idcard(CODE) VALUES('152201199008150317');

# 创建一个名称为tb_person的表

 CREATE TABLE tb_person(
     id INT PRIMARY KEY AUTO_INCREMENT,
     name VARCHAR(32),
     age INT,
     sex VARCHAR(8),
     card_id INT UNIQUE,
     FOREIGN KEY(card_id) REFERENCES tb_idcard(id)
     );

# 插入2条数据

INSERT INTO tb_person(name, age,sex,card_id) VALUES('Rose','22','女',1);

INSERT INTO tb_person(name, age,sex,card_id) VALUES('jack','23','男',2);

 

 

2. 永続クラス IDCard: ID カード属性をカプセル化する永続クラス IdCard を作成します。

public class Idcard {
    private Integer id; //主键id

    private String code; //身份证号码

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getCode() {
        return code;
    }

    public void setCode(String code) {
        this.code = code;
    }

    @Override

    public String toString() {

        return "IdCard [id=" + id + ", code=" + code + "]";

    }
}

3. 永続的な Person クラス: 個人の属性をカプセル化するための永続的な Person クラスを作成します。 

public class Person {
        private Integer id;             // 主键id
        private String name;         // 姓名
        private Integer age;          // 年龄
        private String sex;            // 性别
        private IdCard card;  	   // 人员关联的证件

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    public Idcard getCard() {
        return card;
    }

    public void setCard(Idcard card) {
        this.card = card;
    }

    @Override
    public String toString() {
        return "Person{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", sex='" + sex + '\'' +
                ", card=" + card +
                '}';
    }
}

4. IdCardMapper.xml ファイルを書き込みます。ID カード マッピング ファイル IdCardMapper.xml を作成し、マッピング ファイルに 1 対 1 関連付けマッピング クエリの構成情報を書き込みます。 

<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"

    "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.mac.mapper.IdCardMapper">

  <!-- 根据id查询证件信息 -->

  <select id="findCodeById" parameterType="Integer" resultType="IdCard">

  SELECT * from tb_idcard where id=#{id}

  </select>

</mapper>

5. PersonMapper.xml ファイルを作成します。人物マッピング ファイル PersonMapper.xml を作成し、マッピング ファイルに 1 対 1 関連付けマッピング クエリの構成情報を書き込みます。 

<select id="findPersonById" parameterType="Integer" resultMap="IdCardWithPersonResult">

SELECT * from tb_person where id=#{id} </select>

<resultMap type="Person" id="IdCardWithPersonResult">

<id property="id" column="id" />

<result property="name" column="name" />

<result property="age" column="age" />

<result property="sex" column="sex" />

<association property="card" column="card_id" javaType="IdCard”

      select="com.mac.mapper.IdCardMapper.findCodeById" />

</resultMap>

6. マッピング ファイルのインポート: コア構成ファイル mybatis-config.xml で、IdCardMapper.xml および PersonMapper.xml マッピング ファイルをインポートし、com.mac.pojo パッケージの下のすべてのエンティティ クラスのエイリアスを定義します。 

<!-- 只展示了定义别名和mapping文件中配置新添加的部分-- >

<!--使用扫描包的形式定义别名 -->

<typeAliases>

<package name="com.mac.pojo" />

</typeAliases>

<mappers>

<mapper resource="com/mac/mapper/IdCardMapper.xml" />

<mapper resource="com/mac/mapper/PersonMapper.xml" />

</mappers>

7. テスト クラスを作成します。テスト クラス MyBatisTest に、テスト メソッド findpersonByIdTest() を作成します。 

public void findPersonByIdTest() {

        // 1、通过工具类获取SqlSession对象

        SqlSession session = MyBatisUtils.getSession();

        // 2.使用MyBatis嵌套查询的方式查询id为1的人的信息

        Person person = session.selectOne("com.mac.mapper." 

                                   + "PersonMapper.findPersonById", 1);

        // 3、输出查询结果信息

        System.out.println(person);

        // 4、关闭SqlSession

        session.close();

    }

トリックを学ぶ: MyBatis 遅延読み込み設定 

        MyBatis ネストされたクエリ メソッドを使用して MyBatis 関連マッピング クエリを実行する場合、MyBatis の遅延読み込みを使用すると、実行消費量が削減され、クエリ効率がある程度向上します。MyBatis はデフォルトでは遅延ロードを有効にしていないため、mybatis-config.xml の <settings> 要素で設定する必要があります。

<settings>

    <!-- 打开延迟加载的开关 -->  

    <setting name="lazyLoadingEnabled" value="true" />  

    <!-- 将积极加载改为消息加载,即按需加载 -->  

    <setting name="aggressiveLazyLoading" value="false"/>  

</settings>

おすすめ

転載: blog.csdn.net/W_Fe5/article/details/131539820