快速學習Spring Data JPA -- 第二章JAP核心類Repository
阿新 • • 發佈:2018-11-01
xl_echo編輯整理,交流學習請加1280023003 百戰不敗,依不自稱常勝,百敗不頹,依能奮力前行。——這才是真正的堪稱強大!!
在SpringDataJPA中最為核心的一個類就是Repository,他是SpringData裡面最底層最抽象的介面,最頂級的父類,原碼裡面其方法都沒有,僅僅起到一個標識作用。
我們可以通過IDEA瞭解一下該類,它的原碼相對簡單
//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by Fernflower decompiler)
//
package org.springframework.data.repository;
import org.springframework.stereotype.Indexed;
@Indexed
public interface Repository<T, ID> {
}
通過原碼我們可以看到,其實它的操作主要不在於這個介面,而是在於繼承它的子接口裡面。現在用的最多的也就是JpaRepository,如果我們開啟這類就可以發現,我們需要的基本的方法都可以在裡面找到。
在這裡我們可以借用idea的工具視窗type hierarchy(點選Navigate > 選中type hierarchy即可, 注意要在該類開啟的情況下點選) 開啟之後我們就可以明確的看到繼承於它的子類關係圖。
雖然我們的通過圖發現這個介面並沒有看到操作資料庫的方法,但是這個繼承這個介面能不能讓我們操作資料庫呢?雖然沒有定義方法,但是它是JPA的核心類,而且他也遵循JPA編寫方法的規則,能夠有效的操作資料庫。
JPA編寫方法操作資料庫只需要使用常用關鍵詞按照sql的思路即可。
常用關鍵詞如下:
- 1 And 並且
- 2 Or 或
- 3 Is,Equals 等於
- 4 Between 兩者之間
- 5 LessThan 小於
- 6 LessThanEqual 小於等於
- 7 GreaterThan 大於
- 8 GreaterThanEqual 大於等於
- 9 After 之後(時間) >
- 10 Before 之前(時間) <
- 11 IsNull 等於Null
- 12 IsNotNull,NotNull 不等於Null
- 13 Like 模糊查詢。查詢件中需要自己加 %
- 14 NotLike 不在模糊範圍內。查詢件中需要自己加 %
- 15 StartingWith 以某開頭
- 16 EndingWith 以某結束
- 17 Containing 包含某
- 18 OrderBy 排序
- 19 Not 不等於
- 20 In 某範圍內
- 21 NotIn 某範圍外
- 22 True 真
- 23 False 假
- 24 IgnoreCase 忽略大小寫
常用方法可以參考下圖
我們也可以使用第一章的專案自己建立一個UserRepository來繼承Repository然後自己定義幾個方法來實際操作
package com.echo.example.example.repository;
import com.echo.example.example.entity.User;
import org.springframework.data.repository.Repository;
import java.util.List;
/**
* author:XLecho
* Date:2018/10/25 0025
* Time:22:26
*/
public interface UserRepositoryExtendsRepository extends Repository<User, Long> {
/**
* 根據名稱查詢使用者列表
* @param name
* @return
*/
List<User> findByName(String name);
/**
* 根據id查詢使用者
* @param id
* @return
*/
User findByIdAnd(Integer id);
}