国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

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

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

服務(wù)器之家 - 編程語言 - Java教程 - Spring Data JDBC介紹及實(shí)現(xiàn)代碼

Spring Data JDBC介紹及實(shí)現(xiàn)代碼

2021-06-02 14:16解道 Java教程

這篇文章主要介紹了Spring Data JDBC介紹及實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

spring新增了一個(gè)新的數(shù)據(jù)模塊:spring data jdbc。spring data jdbc背后的想法是提供對關(guān)系數(shù)據(jù)庫的訪問,而無需處理jpa的復(fù)雜性。jpa提供延遲加載,緩存和臟跟蹤等功能。果你需要這些功能會(huì)很很棒,但會(huì)讓猜測jpa的行為比非jpa更難。

延遲加載可能會(huì)在你不需要時(shí)觸發(fā)昂貴的語句,或者它可能會(huì)因異常而失敗。當(dāng)你想要比較一個(gè)實(shí)體的兩個(gè)版本是哪個(gè)變成臟數(shù)據(jù)時(shí),緩存可能會(huì)妨礙你,讓你很難找到所有持久性操作都通過的那個(gè)點(diǎn)。

spring data jdbc目標(biāo)是實(shí)現(xiàn)更簡單的模型,不會(huì)有緩存,臟數(shù)據(jù)跟蹤或延遲加載。相反,只有在調(diào)用數(shù)據(jù)庫方法時(shí)才會(huì)發(fā)出sql語句。方法返回的對象會(huì)完全加載,不會(huì)有延遲。實(shí)體沒有“會(huì)話”和代理。所有這些都應(yīng)該使spring data jdbc更易于推理。

當(dāng)然,這種更簡單的方法會(huì)導(dǎo)致約束。

我們來看一個(gè)簡單的例子。

首先,我們需要一個(gè)實(shí)體:

?
1
2
3
4
5
6
class customer {
  @id
  long id;
  string firstname;
  localdate dob;
}

請注意,不需要getter或setter。如果您意,可以增加。實(shí)際上,唯一的要求是實(shí)體有一個(gè)注釋的屬性id(即@org.springframework.data.annotation.id,注意不是javax.persistence,后者是jpa)。

接下來,我們需要聲明一個(gè)存儲(chǔ)庫。最簡單的方法是擴(kuò)展crudrepository:

?
1
interface customerrepository extends crudrepository<customer, long> {}

最后,我們需要配置applicationcontext以啟用存儲(chǔ)庫的創(chuàng)建:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
@configuration
@enablejdbcrepositories (1)
public class customerconfig extends jdbcconfiguration { (2)
 
  @bean
  namedparameterjdbcoperations operations() { (3)
    return new namedparameterjdbctemplate(datasource());
  }
 
  @bean
  platformtransactionmanager transactionmanager() { (4)
    return new datasourcetransactionmanager(datasource());
 }
 
  @bean
  datasource datasource(){ (5)
    return new embeddeddatabasebuilder()
        .generateuniquename(true)
        .settype(embeddeddatabasetype.hsql)
        .addscript("create-customer-schema.sql")
        .build();
  }
}

讓我們一步一步地解釋。

1. enablejdbcrepositories可以創(chuàng)建存儲(chǔ)庫。由于它需要存在一些bean,我們需要其余的配置。

2. 繼承擴(kuò)展的jdbcconfiguration將一些默認(rèn)bean添加到applicationcontext。可以覆蓋其方法以自定義spring data jdbc的某些行為。現(xiàn)在,我們使用默認(rèn)實(shí)現(xiàn)。

3. 真正重要的部分是namedparameterjdbcoperations,它在內(nèi)部用于向數(shù)據(jù)庫提交sql語句。

4. 嚴(yán)格來說,事務(wù)管理器不是必需的。不支持跨越多個(gè)sql語句的事務(wù)。

5. spring data jdbc沒有直接使用datasource,但是,由于transactionmanager和namedparameterjdbcoperations需要,將datasource注冊為bean是一種確保兩者使用相同實(shí)例的簡單方法。

這就是一切。現(xiàn)在讓我們測試玩玩:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
@runwith(springrunner.class)
@transactional
@contextconfiguration(classes = customerconfig.class)
public class customerrepositorytest {
 
  @autowired customerrepository customerrepo;
 
  @test
  public void createsimplecustomer() {
 
    customer customer = new customer();
    customer.dob = localdate.of(1904, 5, 14);
    customer.firstname = "albert";
 
    customer saved = customerrepo.save(customer);
 
    assertthat(saved.id).isnotnull();
 
    saved.firstname = "hans albert";
 
    customerrepo.save(saved);
 
    optional<customer> reloaded = customerrepo.findbyid(saved.id);
 
    assertthat(reloaded).isnotempty();
 
    assertthat(reloaded.get().firstname).isequalto("hans albert");
  }
}

@query 注解

你可能不會(huì)只使用基本的crud方法crudrepository。可以使用簡單的@query注釋來指定存儲(chǔ)庫方法的查詢:

?
1
2
@query("select id, first_name, dob from customer where upper(first_name) like '%' || upper(:name) || '%' ")
list<customer> findbyname(@param("name") string name);

請注意,@param如果使用-parameters標(biāo)志進(jìn)行編譯,則不需要注釋。

如果要執(zhí)行更新或刪除語句,可以使用@modifying向方法添加注釋。

讓我們創(chuàng)建另一個(gè)測試以試用新方法。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
@test
public void findbyname() {
 
  customer customer = new customer();
  customer.dob = localdate.of(1904, 5, 14);
  customer.firstname = "albert";
 
  customer saved = customerrepo.save(customer);
 
  assertthat(saved.id).isnotnull();
 
  customer.id= null; (1)
  customer.firstname = "bertram";
 
  customerrepo.save(customer);
 
  customer.id= null;
  customer.firstname = "beth";
 
  customerrepo.save(customer);
 
  assertthat(customerrepo.findbyname("bert")).hassize(2); (2)
}

由于java對象與其對應(yīng)行之間的連接是id類型,因此設(shè)置id為null并再次保存它會(huì)在數(shù)據(jù)庫中創(chuàng)建另一行。

我們正在進(jìn)行不區(qū)分大小寫(例如)搜索,因此,我們找到“albert”和“bertram”,但不是“beth”。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://www.jdon.com/50191

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩一区不卡 | 91亚洲国产成人久久精品网站 | 午夜视频导航 | 久草成人网 | 久久男人天堂 | 国产成人久久精品一区二区三区 | av久草| 日韩一区二区三区在线观看 | 久久精品国产亚洲 | 亚洲黄色成人 | 在线一区观看 | 国内成人免费视频 | 激情久久久久 | 亚洲精品黄色 | 免费在线观看一区二区 | 日韩福利在线 | 一区二区免费在线视频 | 久久综合久久综合久久综合 | 国产日韩欧美一区二区 | 亚洲www视频 | 大片免费播放在线观看视频 | 色花av | 亚洲成人精品一区 | 欧美国产高清 | 精品久久久av | 黄网站在线播放 | 国产精品99在线观看 | 欧美一区二区黄 | 成人精品| aaa级大片| 国产精品美女高潮无套久久 | 一本色道久久综合狠狠躁篇怎么玩 | 久久久精品免费观看 | 国产综合区 | 四虎永久免费影视 | 神马影院一区二区三区 | 亚洲国产aⅴ成人精品无吗 黄色免费在线看 | 91 在线| 亚洲精品乱码久久久久久蜜糖图片 | 欧美福利一区二区 | 欧美精品久久 |