亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Spring Data JDBC介紹及實現代碼

2024-07-14 08:42:27
字體:
來源:轉載
供稿:網友

Spring新增了一個新的數據模塊:Spring Data JDBC。Spring Data JDBC背后的想法是提供對關系數據庫的訪問,而無需處理JPA的復雜性。JPA提供延遲加載,緩存和臟跟蹤等功能。果你需要這些功能會很很棒,但會讓猜測JPA的行為比非JPA更難。

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

Spring Data JDBC目標是實現更簡單的模型,不會有緩存,臟數據跟蹤或延遲加載。相反,只有在調用數據庫方法時才會發出SQL語句。方法返回的對象會完全加載,不會有延遲。實體沒有“會話”和代理。所有這些都應該使Spring Data JDBC更易于推理。

當然,這種更簡單的方法會導致約束。

我們來看一個簡單的例子。

首先,我們需要一個實體:

class Customer {  @Id  Long id;  String firstName;  LocalDate dob;}

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

接下來,我們需要聲明一個存儲庫。最簡單的方法是擴展CrudRepository:

interface CustomerRepository extends CrudRepository<Customer, Long> {}

最后,我們需要配置ApplicationContext以啟用存儲庫的創建:

@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可以創建存儲庫。由于它需要存在一些bean,我們需要其余的配置。

2. 繼承擴展的JdbcConfiguration將一些默認bean添加到ApplicationContext??梢愿采w其方法以自定義Spring Data JDBC的某些行為。現在,我們使用默認實現。

3. 真正重要的部分是NamedParameterJdbcOperations,它在內部用于向數據庫提交SQL語句。

4. 嚴格來說,事務管理器不是必需的。不支持跨越多個SQL語句的事務。

5. Spring Data JDBC沒有直接使用DataSource,但是,由于TransactionManager和NamedParameterJdbcOperations需要,將DataSource注冊為bean是一種確保兩者使用相同實例的簡單方法。

這就是一切?,F在讓我們測試玩玩:

@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 注解

你可能不會只使用基本的CRUD方法CrudRepository。可以使用簡單的@Query注釋來指定存儲庫方法的查詢:

@Query("select id, first_name, dob from customer where upper(first_name) like '%' || upper(:name) || '%' ")List<Customer> findByName(@Param("name") String name);

請注意,@Param如果使用-parameters標志進行編譯,則不需要注釋。

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

讓我們創建另一個測試以試用新方法。

@Testpublic 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對象與其對應行之間的連接是Id類型,因此設置Id為null并再次保存它會在數據庫中創建另一行。

我們正在進行不區分大小寫(例如)搜索,因此,我們找到“Albert”和“Bertram”,但不是“Beth”。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91高潮在线观看| 国语自产偷拍精品视频偷| 97香蕉超级碰碰久久免费软件| 日韩精品视频在线免费观看| 日韩中文字幕视频| 动漫精品一区二区| 久久久999成人| 青青青国产精品一区二区| 最近中文字幕mv在线一区二区三区四区| 精品国产1区2区| 国产精品jvid在线观看蜜臀| 日韩av在线最新| 欧美午夜女人视频在线| 精品久久中文字幕久久av| 久久久久国产精品免费网站| 亚洲精品日韩在线| 国产精品久久久久久久久久免费| 国产一区二区三区在线播放免费观看| 一色桃子一区二区| 亚洲а∨天堂久久精品喷水| 亚洲第一免费播放区| 日本精品视频在线播放| 国产精品香蕉国产| 粗暴蹂躏中文一区二区三区| 日韩av电影手机在线| 美女av一区二区三区| 久久久久久久久国产精品| 一本色道久久综合狠狠躁篇怎么玩| 久久久欧美精品| 7777免费精品视频| 日韩精品视频在线免费观看| 久久99精品国产99久久6尤物| 欧美日韩午夜视频在线观看| 久久久精品一区二区| 久久国产精品久久久久| 久久伊人色综合| 亚洲最大的av网站| 国产精品男人的天堂| 青青草精品毛片| 亚洲欧美国产一区二区三区| 欧美日韩亚洲成人| 午夜精品视频在线| 亚洲免费成人av电影| 亚洲免费福利视频| 国产精品久在线观看| xxxxx成人.com| 国产啪精品视频网站| 国产aⅴ夜夜欢一区二区三区| 国产拍精品一二三| 久久91亚洲精品中文字幕奶水| 91久久久久久久久久| 高清欧美一区二区三区| 国产成人精品视频| 91超碰中文字幕久久精品| 日韩中文在线观看| 亚洲第一国产精品| 亚洲美女免费精品视频在线观看| 人人做人人澡人人爽欧美| 色噜噜国产精品视频一区二区| 一区二区三区在线播放欧美| 欧美日产国产成人免费图片| 久久久国产视频91| 国产成人精彩在线视频九色| 亚洲国产精品va在线看黑人| 日韩欧美中文字幕在线播放| 亚洲国产私拍精品国模在线观看| 国产成人久久久精品一区| 欧美性高潮在线| 久久久亚洲影院| 欧美日韩在线第一页| 国外成人在线播放| 色噜噜狠狠色综合网图区| 国产精自产拍久久久久久| 国产欧美在线播放| 中文字幕欧美日韩精品| 久久久天堂国产精品女人| 成人在线精品视频| 日韩av电影国产| 欧美一级片免费在线| 国产色视频一区| 久久久欧美一区二区| 欧美性感美女h网站在线观看免费| 国产一区二区视频在线观看| 日韩在线一区二区三区免费视频| 国产精品69久久| 欧美国产日韩中文字幕在线| 国产精品一区二区三区久久久| 日韩在线视频一区| 欧美性视频网站| 精品美女久久久久久免费| 欧美高清无遮挡| 亚洲最大福利视频网站| 亚洲一区二区三区在线免费观看| 国产精品扒开腿做爽爽爽男男| 78色国产精品| 81精品国产乱码久久久久久| 91色p视频在线| 欧美激情亚洲综合一区| 国产91在线播放| 亚洲欧美国产日韩中文字幕| 国产精品入口日韩视频大尺度| 欧美色另类天堂2015| 91大神福利视频在线| 欧美日韩中文字幕在线| 中文字幕日韩免费视频| 一区二区三区在线播放欧美| 成人精品视频在线| 97在线看免费观看视频在线观看| 日韩欧美中文免费| 国产精品自拍小视频| 一区二区在线免费视频| 日韩一区二区av| 亚洲欧美国产一本综合首页| 日韩精品在线免费| 欧美精品在线看| 久久国产精彩视频| 色伦专区97中文字幕| 亚洲欧洲中文天堂| 欧美性猛交视频| 日韩精品极品在线观看播放免费视频| 欧美综合在线第二页| 欧美日韩精品中文字幕| 国产精品一区二区电影| 久久精品国产免费观看| 亚洲美女黄色片| 国产一区二区黑人欧美xxxx| 欧美国产日韩一区二区在线观看| 这里只有精品视频在线| 国产精品久久久| 亚洲女人天堂色在线7777| 亚洲资源在线看| 久久国产精品网站| 国产精品老女人精品视频| 亚洲欧洲免费视频| 日韩黄色高清视频| 亚洲欧美在线一区| 色噜噜狠狠狠综合曰曰曰| 久久这里只有精品99| 久久精品精品电影网| 亚洲国产高清福利视频| 久久久成人av| 爱福利视频一区| 亚洲日韩欧美视频一区| 精品久久久久久国产| 亚洲国产成人av在线| 欧美性xxxxx极品| 中文字幕av一区| 欧美天天综合色影久久精品| 成人黄色免费在线观看| 午夜精品视频在线| 欧美网站在线观看| 九九热这里只有精品免费看| 欧美激情视频在线免费观看 欧美视频免费一| 高清在线视频日韩欧美| 91在线中文字幕| 亚洲人成在线电影| 美乳少妇欧美精品| 久久久久久久久久久久av| 欧美xxxx14xxxxx性爽| 最近2019中文字幕大全第二页| 欧美成人手机在线| 日韩在线免费观看视频| 国产小视频91| 国产日韩欧美91|