亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解使用Spring?Data?repository進行數(shù)據(jù)層的訪問問題

 更新時間:2022年06月13日 15:39:04   作者:你呀不牛  
這篇文章主要介紹了使用Spring?Data?repository進行數(shù)據(jù)層的訪問,抽象出Spring Data repository是因為在開發(fā)過程中,常常會為了實現(xiàn)不同持久化存儲的數(shù)據(jù)訪問層而寫大量的大同小異的代碼,本文給大家介紹的非常詳細,需要的朋友參考下吧

使用Spring Data repository進行數(shù)據(jù)層的訪問

抽象出Spring Data repository是因為在開發(fā)過程中,常常會為了實現(xiàn)不同持久化存儲的數(shù)據(jù)訪問層而寫大量的大同小異的代碼。

Spring Data repository的目的就是要大幅減少這些重復的代碼。 Spring Data Elasticsearch為文檔的存儲,查詢,排序和統(tǒng)計提供了一個高度抽象的模板。

核心概念

Spring Data repository抽象中最核心的接口就是Repository。該接口使用了泛型,需要提供兩個類型參數(shù),

  • 第一個是接口處理的域?qū)ο箢愋?/li>
  • 第二個是域?qū)ο蟮闹麈I類型。

這個接口常被看做是一個標記型接口,用來獲取要操作的域?qū)ο箢愋秃蛶椭_發(fā)者識別繼承這個類的接口。在Repository的基礎上,CrudRepository接口提供了針對實體類的復雜的CRUD(增刪改查)操作。

public interface CrudRepository<T, ID extends Serializable>
    extends Repository<T, ID> {
    <S extends T> S save(S entity); 
    T findOne(ID primaryKey);       
    Iterable<T> findAll();          
    Long count();                   
    void delete(T entity);          
    boolean exists(ID primaryKey);  
    // … more functionality omitted.
}

PagingAndSortingRepository接口在CrudRepository的基礎上增加了一些方法,使開發(fā)者可以方便的對實體類進行分頁和排序。

public interface PagingAndSortingRepository<T, ID extends Serializable>
  extends CrudRepository<T, ID> {
  Iterable<T> findAll(Sort sort);
  Page<T> findAll(Pageable pageable);
}

在分頁長度為20的基礎上,想要獲取第二頁的User數(shù)據(jù),代碼如下

PagingAndSortingRepository<User, Long> repository = // … get access to a bean
Page<User> users = repository.findAll(new PageRequest(1, 20));

查詢方法

標準的CRUD(增刪改查)功能都要使用查詢語句來查詢數(shù)據(jù)庫。但通過使用Spring Data,只要五個步驟就可以實現(xiàn)。

  • 創(chuàng)建一個Domain類
@Entity
@Document
public class Person {
  …
}
  • 聲明一個繼承Repository接口或其子接口的持久層接口。并標明要處理的域?qū)ο箢愋图捌渲麈I的類型(在下面的例子中,要處理的域?qū)ο笫荘erson,其主鍵類型是Long)
interface PersonRepository extends Repository<Person, Long> { … }
  • 在接口中聲明查詢方法(spring會為其生成實現(xiàn)代碼)
interface PersonRepository extends Repository<Person, Long> {
  List<Person> findByLastname(String lastname);
}
  • 讓Spring創(chuàng)建對這些接口的代理實例。

使用JavaConfig的方式

import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
@EnableJpaRepositories
class Config {}

使用xml配置的方式

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xmlns:jpa="http://www.springframework.org/schema/data/jpa"
   xsi:schemaLocation="http://www.springframework.org/schema/beans
     http://www.springframework.org/schema/beans/spring-beans.xsd
     http://www.springframework.org/schema/data/jpa
     http://www.springframework.org/schema/data/jpa/spring-jpa.xsd">
   <jpa:repositories base-package="com.acme.repositories"/>
</beans>

注入repository實例,并使用

public class SomeClient {
  @Autowired
  private PersonRepository repository;
  public void doSomething() {
    List<Person> persons = repository.findByLastname("Matthews");
  }
}

定義查詢方法

CREATE

Spring Data repository自帶了一個非常有用的查詢構(gòu)造器。它會從方法名中去掉類似find..By,read...By,query...By,count...By之類的前綴,然后解析剩余的名字。我們也可以在方法名中加入更多的表達式,比如查詢時需要distinct約束,那么在方法名中加入Distinct即可。方法名中的第一個By是一個分解符,代表著查詢語句的開始,我們可以用And或Or來將多個查詢條件關聯(lián)起來。

public interface PersonRepository extends Repository<User, Long> {
  List<Person> findByEmailAddressAndLastname(EmailAddress emailAddress, String lastname);
  // Enables the distinct flag for the query
  List<Person> findDistinctPeopleByLastnameOrFirstname(String lastname, String firstname);
  List<Person> findPeopleDistinctByLastnameOrFirstname(String lastname, String firstname);
  // Enabling ignoring case for an individual property
  List<Person> findByLastnameIgnoreCase(String lastname);
  // Enabling ignoring case for all suitable properties
  List<Person> findByLastnameAndFirstnameAllIgnoreCase(String lastname, String firstname);
  // Enabling static ORDER BY for a query
  List<Person> findByLastnameOrderByFirstnameAsc(String lastname);
  List<Person> findByLastnameOrderByFirstnameDesc(String lastname);
}

除此之外,我們還可以為方法添加某些特定類型的參數(shù)(如:Pageable和Sort)來動態(tài)的在查詢中添加分頁和排序。

Page<User> findByLastname(String lastname, Pageable pageable);
Slice<User> findByLastname(String lastname, Pageable pageable);
List<User> findByLastname(String lastname, Sort sort);
List<User> findByLastname(String lastname, Pageable pageable);

USE_DECLARED_QUERY

如果方法通過 @Query 指定了查詢語句,則使用該語句創(chuàng)建Query;如果沒有,則查找是否定義了符合條件的Named Query,如果找到,則使用該命名查詢;如果兩者都沒有找到,則拋出異常。使用@Query聲明查詢語句的例子如下:

//使用Query注解
@Query("select a from AccountInfo a where a.accountId = ?1")
public AccountInfo findByAccountId(Long accountId);

CREATE_IF_NOT_FOUND

結(jié)合了CREATE和USE_DECLARED_QUERY 兩種策略,會先嘗試查找聲明好的查詢,如果沒有找到,就按照解析方法名的方式構(gòu)建查詢。這是默認的查詢策略,如果不更改配置,會一直使用這種策略構(gòu)建查詢。這種策略支持通過方法名快速定義一個查詢,也允許引入聲明好的查詢。

WEB支持

DomainClassConverter 允許開發(fā)者在SpringMVC控制層的方法中直接使用域?qū)ο箢愋?Domain types),而無需通過repository手動查找這個實例。

@Controller
@RequestMapping("/users")
public class UserController {
  @RequestMapping("/{id}")
  public String showUserForm(@PathVariable("id") User user, Model model) {
    model.addAttribute("user", user);
    return "userForm";
  }
}

上面的方法直接接收了一個User對象,開發(fā)者不需要做任何的搜索操作,轉(zhuǎn)換器會自動將路徑變量id轉(zhuǎn)為User對象的id,并且調(diào)用了findOne()方法查詢出User實體。 注意:當前的Repository 必須實現(xiàn)CrudRepository

HandlerMethodArgumentResolver使開發(fā)者可以在controller的方法中使用Pageable和Sort作為參數(shù)。

@Controller
@RequestMapping("/users")
public class UserController {
  @Autowired UserRepository repository;
  @RequestMapping
  public String showUsers(Model model, Pageable pageable) {
    model.addAttribute("users", repository.findAll(pageable));
    return "users";
  }
}

通過上面的方法定義,Spring MVC會使用下面的默認配置嘗試從請求參數(shù)中得到一個Pageable的實例。

參數(shù)名作用
page想要獲取的頁數(shù),默認為0
size獲取頁的大小,默認為20
page需要排序的屬性,格式為property,property(,ASC/DESC),默認升序排序。支持多個字段排序,比如?sort=firstname&sort=lastname,asc

開發(fā)者也可以針對多個表定義多個Pageable或Sort實例,需要使用Spring的@Qualifier注解來區(qū)分它們。并且請求參數(shù)名要帶有${qualifier}_的前綴。例子如下:

public String showUsers(Model model,
      @Qualifier("foo") Pageable first,
      @Qualifier("bar") Pageable second) { … }

請求中需要帶有foo_page和bar_page等參數(shù)。

到此這篇關于使用Spring Data repository進行數(shù)據(jù)層的訪問的文章就介紹到這了,更多相關Spring Data repository數(shù)據(jù)層訪問內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 使用Spring MVC攔截器實現(xiàn)日志記錄的方法

    使用Spring MVC攔截器實現(xiàn)日志記錄的方法

    本篇文章主要介紹了使用Spring MVC攔截器實現(xiàn)日志記錄的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • java正則實現(xiàn)各種日期格式化

    java正則實現(xiàn)各種日期格式化

    本文給大家分享的是使用java結(jié)合正則表達式來實現(xiàn)各種日期的格式化功能,代碼非常的簡單,有需要的小伙伴可以參考下。
    2015-05-05
  • maven多moudle項目在idea里面顯示多個root問題及解決

    maven多moudle項目在idea里面顯示多個root問題及解決

    這篇文章主要介紹了maven多moudle項目在idea里面顯示多個root問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Spring數(shù)據(jù)庫連接池實現(xiàn)原理深入刨析

    Spring數(shù)據(jù)庫連接池實現(xiàn)原理深入刨析

    開發(fā)web項目,我們肯定會和數(shù)據(jù)庫打交道,因此就會涉及到數(shù)據(jù)庫鏈接的問題。在以前我們開發(fā)傳統(tǒng)的SSM結(jié)構(gòu)的項目時進行數(shù)據(jù)庫鏈接都是通過JDBC進行數(shù)據(jù)鏈接,我們每和數(shù)據(jù)庫打一次交道都需要先獲取一次鏈接,操作完后再關閉鏈接,這樣子效率很低,因此就出現(xiàn)了連接池
    2022-11-11
  • Java中幾個Reference常見的作用詳解

    Java中幾個Reference常見的作用詳解

    這篇文章主要給大家介紹了Java中關于Reference多個作用的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起來學習學習吧。
    2017-06-06
  • 簡單的java讀取文件示例分享

    簡單的java讀取文件示例分享

    這篇文章主要介紹了java讀取txt文件內(nèi)容,示例很簡單,代碼里有注釋,大家直接看代碼吧
    2014-01-01
  • 使用SpringBoot整合Jpa的過程詳解

    使用SpringBoot整合Jpa的過程詳解

    SpringBoot是一種快速開發(fā)框架,它簡化了Java應用程序的開發(fā)過程,而Jpa是Java持久化規(guī)范的一種實現(xiàn),將SpringBoot與Jpa整合可以更加方便地進行數(shù)據(jù)庫操作,提高開發(fā)效率,本文將介紹如何使用Spring Boot整合Jpa,幫助讀者快速上手并應用于實際項目中
    2023-12-12
  • XML操作類庫XStream使用詳解

    XML操作類庫XStream使用詳解

    這篇文章主要給大家介紹了關于XML操作類庫XStream使用的相關資料,需要的朋友可以參考下
    2023-11-11
  • Java中@DS+@Transactional注解切換數(shù)據(jù)源失效解決方案

    Java中@DS+@Transactional注解切換數(shù)據(jù)源失效解決方案

    本文主要介紹了@DS+@Transactional注解切換數(shù)據(jù)源失效解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • JDBC連接MYSQL分步詳解

    JDBC連接MYSQL分步詳解

    JDBC是指Java數(shù)據(jù)庫連接,是一種標準Java應用編程接口(?JAVA?API),用來連接?Java?編程語言和廣泛的數(shù)據(jù)庫。從根本上來說,JDBC?是一種規(guī)范,它提供了一套完整的接口,允許便攜式訪問到底層數(shù)據(jù)庫,本篇文章我們來了解MySQL連接JDBC的流程方法
    2022-03-03

最新評論