欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis中一對(duì)一、一對(duì)多的<association> 配置使用

 更新時(shí)間:2025年05月09日 10:33:34   作者:小玉起起  
<association>?是 MyBatis 中處理一對(duì)一或一對(duì)多關(guān)系的映射元素,用于處理一對(duì)一和一對(duì)多關(guān)系的映射,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

<association> 是 MyBatis 中處理一對(duì)一或一對(duì)多關(guān)系的映射元素,用于將查詢(xún)結(jié)果中的嵌套數(shù)據(jù)映射到 Java 對(duì)象的屬性中。它常用于表示對(duì)象之間的關(guān)聯(lián)關(guān)系,尤其是在復(fù)雜的數(shù)據(jù)庫(kù)查詢(xún)結(jié)果需要映射為嵌套對(duì)象時(shí)。

1. 作用與用途

  • 一對(duì)一關(guān)系:當(dāng)一個(gè)對(duì)象包含一個(gè)關(guān)聯(lián)對(duì)象時(shí)(例如,一個(gè) User 只對(duì)應(yīng)一個(gè) Address),可以使用 <association> 映射一對(duì)一關(guān)系。
  • 一對(duì)多關(guān)系:當(dāng)一個(gè)對(duì)象包含多個(gè)關(guān)聯(lián)對(duì)象時(shí)(例如,一個(gè) Org 對(duì)應(yīng)多個(gè) User),可以使用 <association> 映射一對(duì)多關(guān)系。
  • 多級(jí)嵌套映射:當(dāng)查詢(xún)涉及多個(gè)關(guān)聯(lián)對(duì)象時(shí),<association> 可以幫助將查詢(xún)結(jié)果自動(dòng)填充到 Java 對(duì)象中,避免手動(dòng)編寫(xiě)復(fù)雜的映射代碼。

2. <association> 基本用法

  • property:Java 對(duì)象中用于存儲(chǔ)關(guān)聯(lián)對(duì)象的屬性名。
  • resultMap:指定一個(gè) resultMap,指明如何將查詢(xún)結(jié)果中的字段映射到該關(guān)聯(lián)對(duì)象。
  • columnPrefix:為數(shù)據(jù)庫(kù)列加上前綴,避免列名沖突。

3. 示例說(shuō)明:一對(duì)一與一對(duì)多映射

假設(shè)有兩個(gè)實(shí)體:User 和 Address,以及 Org 和多個(gè) User,我們分別演示如何使用 <association> 進(jìn)行一對(duì)一和一對(duì)多的映射。

4. 示例 1:一對(duì)一關(guān)聯(lián)映射

數(shù)據(jù)表結(jié)構(gòu)

假設(shè)數(shù)據(jù)庫(kù)中有兩張表:users 和 address。

users 表:存儲(chǔ)用戶(hù)信息

user_iduser_name
1Alice
2Bob

address 表:存儲(chǔ)地址信息

address_iduser_idstreetcity
11123 MainNYC
22456 ElmLA

1.1 定義 Java 類(lèi)

// User.java
public class User {
    private int id;
    private String name;
    private Address address;  // 一對(duì)一關(guān)聯(lián)

    // getters and setters
}

// Address.java
public class Address {
    private int id;
    private String street;
    private String city;

    // getters and setters
}

1.2 創(chuàng)建 resultMap

<!-- Address resultMap -->
<resultMap id="addressResultMap" type="com.example.Address">
    <result property="id" column="address_id"/>
    <result property="street" column="street"/>
    <result property="city" column="city"/>
</resultMap>

<!-- User resultMap -->
<resultMap id="userResultMap" type="com.example.User">
    <id property="id" column="user_id"/>
    <result property="name" column="user_name"/>
    <association property="address" resultMap="addressResultMap"/>
</resultMap>

1.3 SQL 查詢(xún)

<select id="findUserWithAddress" resultMap="userResultMap">
    SELECT u.user_id, u.user_name, a.address_id, a.street, a.city
    FROM users u
    LEFT JOIN address a ON u.user_id = a.user_id
    WHERE u.user_id = #{userId}
</select>

1.4 結(jié)果映射

如果查詢(xún) user_id=1,返回如下數(shù)據(jù):

user_iduser_nameaddress_idstreetcity
1Alice1123 MainNYC

結(jié)果會(huì)映射為:

User user = new User();
user.setId(1);
user.setName("Alice");

Address address = new Address();
address.setId(1);
address.setStreet("123 Main");
address.setCity("NYC");

user.setAddress(address);

5. 示例 2:一對(duì)多關(guān)聯(lián)映射

數(shù)據(jù)表結(jié)構(gòu)

假設(shè)有兩張表:org 和 users。

  • org 表:存儲(chǔ)組織信息

    org_idorg_name
    101Finance
    102HR
  • users 表:存儲(chǔ)用戶(hù)信息

    user_iduser_nameorg_id
    1Alice101
    2Bob101
    3Carol102

2.1 定義 Java 類(lèi)

// User.java
public class User {
    private int userId;
    private String userName;

    // getters and setters
}

// Org.java
public class Org {
    private int orgId;
    private String orgName;
    private List<User> users;  // 一對(duì)多關(guān)聯(lián)

    // getters and setters
}

2.2 創(chuàng)建 resultMap

<!-- User resultMap -->
<resultMap id="userResultMap" type="com.example.User">
    <result property="userId" column="user_id"/>
    <result property="userName" column="user_name"/>
</resultMap>

<!-- Org resultMap -->
<resultMap id="orgResultMap" type="com.example.Org">
    <result property="orgId" column="org_id"/>
    <result property="orgName" column="org_name"/>
    <association property="users" resultMap="userResultMap"/>
</resultMap>

2.3 SQL 查詢(xún)

<select id="findOrgWithUsers" resultMap="orgResultMap">
    SELECT o.org_id, o.org_name, u.user_id, u.user_name
    FROM org o
    LEFT JOIN users u ON o.org_id = u.org_id
</select>

2.4 結(jié)果映射

查詢(xún)返回結(jié)果:

org_idorg_nameuser_iduser_name
101Finance1Alice
101Finance2Bob
102HR3Carol

會(huì)映射為:

List<Org> orgs = new ArrayList<>();

// org 1
Org org1 = new Org();
org1.setOrgId(101);
org1.setOrgName("Finance");

User user1 = new User();
user1.setUserId(1);
user1.setUserName("Alice");

User user2 = new User();
user2.setUserId(2);
user2.setUserName("Bob");

org1.setUsers(Arrays.asList(user1, user2));

// org 2
Org org2 = new Org();
org2.setOrgId(102);
org2.setOrgName("HR");

User user3 = new User();
user3.setUserId(3);
user3.setUserName("Carol");

org2.setUsers(Arrays.asList(user3));

// 添加到列表
orgs.add(org1);
orgs.add(org2);

6. 總結(jié)

  • <association> 用途:

    • 一對(duì)一關(guān)系:通過(guò) <association> 映射一個(gè)對(duì)象到另一個(gè)對(duì)象的屬性。
    • 一對(duì)多關(guān)系:通過(guò) <association> 映射多個(gè)對(duì)象到一個(gè)集合屬性。
    • 嵌套結(jié)果映射:支持多級(jí)嵌套查詢(xún),將復(fù)雜的查詢(xún)結(jié)果映射為多層嵌套的 Java 對(duì)象。
  • 常用屬性:

    • property:指定要填充的 Java 類(lèi)屬性。
    • resultMap:指向用于處理該關(guān)聯(lián)對(duì)象映射的 resultMap。
    • columnPrefix:給數(shù)據(jù)庫(kù)列名加前綴,避免列名沖突。
  • 查詢(xún)結(jié)果映射:<association> 會(huì)根據(jù)查詢(xún)返回的結(jié)果自動(dòng)將嵌套對(duì)象填充到 Java 對(duì)象中,簡(jiǎn)化了復(fù)雜的查詢(xún)結(jié)果的處理。

通過(guò)合理使用 <association>,你可以輕松地處理一對(duì)一和一對(duì)多的對(duì)象關(guān)系,避免手動(dòng)編寫(xiě)復(fù)雜的結(jié)果映射代碼,提升代碼的可維護(hù)性和可讀性。

到此這篇關(guān)于mybatis中一對(duì)一、一對(duì)多的<association> 配置使用的文章就介紹到這了,更多相關(guān)mybatis 一對(duì)一、一對(duì)多配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論