激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|JavaScript|易語言|

服務(wù)器之家 - 編程語言 - Java教程 - mybatis中延遲加載Lazy策略的方法

mybatis中延遲加載Lazy策略的方法

2021-05-10 11:31JYLM Java教程

這篇文章主要介紹了mybatis中延遲加載Lazy策略,需要的朋友可以參考下

lazy策略原理:只有在使用查詢sql返回的數(shù)據(jù)是才真正發(fā)出sql語句到數(shù)據(jù)庫,否則不發(fā)出(主要用在多表的聯(lián)合查詢)

1.一對(duì)一延遲加載

假設(shè)數(shù)據(jù)庫中有person表和card表:其中person表中有字段pid,pname,page,psex,cid,card表中有字段cid,cnum;

假設(shè)要查詢某個(gè)人的姓名和身份證號(hào)碼:

原理:在查詢姓名時(shí),實(shí)際本沒有查詢出身份證號(hào)碼的信息,只有當(dāng)前臺(tái)使用身份證號(hào)時(shí)才發(fā)出對(duì)card的查詢,需要查詢出身份證號(hào)碼是采取查詢的一種策略;

實(shí)現(xiàn)實(shí)例:

實(shí)現(xiàn)步驟:

       1-導(dǎo)入mybatis 的依賴jar包

       2-添加log4j文件 (可查看內(nèi)存中實(shí)際執(zhí)行的程序)

1-原理:只有當(dāng)前臺(tái)使用身份證號(hào)時(shí)才發(fā)出對(duì)card的查詢,否則只發(fā)出person信息的查詢
          2-開啟lazy:在conf.xml

?
1
2
3
4
<settings>
    <setting name="lazyloadingenabled" value="true"/>
    <setting name="aggressivelazyloading" value="false"/>
  </settings>

3.實(shí)現(xiàn):

(1)在mapper.xml映射文件中:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<select id="findcid" parametertype="int" resulttype="card">
    select * from card where cid=#{value}
  </select>
  <resultmap type="person" id="p_c1">
    <id column="pid" property="pid" />
    <result column="pname" property="pname" />
    <result column="page" property="page" />
    <result column="psex" property="psex" />
    <association property="card" javatype="card" select="findcid"
      column="cid">
    </association>
  </resultmap>
  <select id="selectpersonandcardlazybypid" parametertype="int"
    resultmap="p_c1">
    select * from person where pid=#{value}
  </select>

     1-select:指定關(guān)聯(lián)的查詢語句

     2-column:指定主語句中的哪個(gè)字段的值作為參數(shù)傳遞給從sql語句

(2)在mapper接口中定義方法:

?
1
public person selectpersonandcardlazybypid(int pid);

(3)使用junit測(cè)試結(jié)果:

1.此處是只發(fā)出person信息的查詢;

?
1
2
3
4
5
6
7
@test
  public void testselectpersonandcardlazybypid(){//lazy策略一對(duì)1
    person p=pm.selectpersonandcardlazybypid(1);
    //system.out.println(p);
    system.out.println(p.getpname()+",");
    //system.out.println(p.getpname()+","+p.getcard().getcnum());
  }

結(jié)果執(zhí)行的查詢語句:

mybatis中延遲加載Lazy策略的方法

2.當(dāng)前臺(tái)使用身份證號(hào)時(shí)才發(fā)出對(duì)card的查詢

?
1
2
3
4
5
6
7
@test
  public void testselectpersonandcardlazybypid(){//lazy策略一對(duì)1
    person p=pm.selectpersonandcardlazybypid(1);
    //system.out.println(p);
    system.out.println(p.getpname()+",");
    system.out.println(p.getpname()+","+p.getcard().getcnum());//當(dāng)前臺(tái)使用身份證號(hào)時(shí)才發(fā)出對(duì)card的查詢
  }

結(jié)果執(zhí)行的查詢語句:

mybatis中延遲加載Lazy策略的方法

2.一對(duì)多延遲加載:

實(shí)現(xiàn)實(shí)例:

假設(shè)數(shù)據(jù)庫中有person表和card身份信息表,adder地址表:其中person表中有字段pid,pname,page,psex,cid,card表中有字段cid,cnum;adder表有字段aid,ashi,pid

假設(shè)要查詢某個(gè)人的姓名和住址,身份證號(hào)碼:

(1)mapper.xml映射文件:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<!-- lazy策略一對(duì)多 -->
  <select id="fingcard_adder" parametertype="int" resulttype="adder">
    select * from adder where pid=#{value}
  </select>
  <select id="findcid1" parametertype="int" resulttype="card">
    select * from card where cid=#{value}
  </select>
  <resultmap type="person" id="p_c1_a1">
    <id column="pid" property="pid" />
    <result column="pname" property="pname" />
    <result column="page" property="page" />
    <result column="psex" property="psex" />
    <association property="card" javatype="card" select="findcid1"
      column="cid">
    </association>
    <collection property="adder" oftype="adder" select="fingcard_adder"
      column="pid">
    </collection>
  </resultmap>
  <select id="selectpersonandcardandadderlazybypid" parametertype="int"
    resultmap="p_c1_a1">
    select * from person where pid=#{value}
  </select>

(2)mapper接口定義方法:

1.此處是只發(fā)出person信息的查詢;

?
1
2
3
4
5
@test
public void testselectpersonandcardandadderlazybypid(){//lazy策略一對(duì)多
  person p=pm.selectpersonandcardandadderlazybypid(1);
  system.out.println(p.getpname()+",");////此處是只發(fā)出person信息的查詢
}

結(jié)果執(zhí)行的查詢語句:

mybatis中延遲加載Lazy策略的方法

2.此處是發(fā)出person信息和身份信息的查詢;

?
1
2
3
4
5
6
@test
public void testselectpersonandcardandadderlazybypid(){//lazy策略一對(duì)多
  person p=pm.selectpersonandcardandadderlazybypid(1);
  system.out.println(p.getpname()+",");//此處是只發(fā)出person信息的查詢;
  system.out.println(p.getpname()+","+p.getcard().getcnum());//此處是發(fā)出person信息和身份信息的查詢;
}

 結(jié)果執(zhí)行的查詢語句:

mybatis中延遲加載Lazy策略的方法

3.此處發(fā)出person信息和身份信息,地址信息的查詢;

?
1
2
3
4
5
6
7
8
9
10
@test
public void testselectpersonandcardandadderlazybypid(){//lazy策略一對(duì)多
  person p=pm.selectpersonandcardandadderlazybypid(1);
  system.out.println(p.getpname()+",");//此處是只發(fā)出person信息的查詢;
  system.out.println(p.getpname()+","+p.getcard().getcnum());//此處是發(fā)出person信息和身份信息的查詢;
  //system.out.println(p.getpname()+","+p.getcard().getcnum());
  for (adder adder : p.getadder()) {////此處發(fā)出person信息和身份信息,地址信息的查詢;
    system.out.println(adder.getashi());
  }  
}

 結(jié)果執(zhí)行的查詢語句:

mybatis中延遲加載Lazy策略的方法

總結(jié)

以上所述是小編給大家介紹的mybatis中延遲加載lazy策略的方法,希望對(duì)大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!

原文鏈接:https://blog.csdn.net/m0_37905429/article/details/77074312

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久国产精品一区 | 国产亚洲精品美女久久久 | 91超视频 | 九九热在线视频观看这里只有精品 | 日日草夜夜草 | 国产91一区二区三区 | 免费毛片小视频 | h视频在线观看免费 | 一级毛片免费高清视频 | 色3344 | 欧美日韩免费观看视频 | 99精品国产一区二区三区 | 黄色毛片一级视频 | 久久亚洲成人 | 国产一区二区国产 | xxxxhdhdhdhd日本| 欧美大电影免费观看 | 久草亚洲视频 | 成人在线免费观看视频 | 一级毛片在线免费观看视频 | 911精品影院在线观看 | 成人午夜免费观看 | 日韩不卡一区二区 | 久久精品色 | 精品一区二区三区免费视频 | 国产精品久久久久久久久久久久久久久 | 伊人一二三四区 | 成人免费av在线播放 | 国产一区二区影视 | 成人毛片100部免费观看 | 9999精品 | 亚州精品在线视频 | 久草在线最新 | 斗罗破苍穹在线观看免费完整观看 | 99ri精品 | 在线观看精品视频 | 国产999视频在线观看 | 麻豆视频在线免费观看 | 久久精品a一级国产免视看成人 | 黄色免费小视频网站 | 国产日韩在线观看一区 |