1. 程式人生 > >快速學習Spring Data JPA -- 第二章JAP核心類Repository

快速學習Spring Data JPA -- 第二章JAP核心類Repository

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);

}

專案地址:https://git.coding.net/xlecho/SpringDataJpa.git