Hibernate、JPA、Spring Data JPA,傻傻分不清
大家好,我是yes。
國(guó)慶假期接近尾聲,明天最后一天了,要開始收收心啦~
今天講講一個(gè)初學(xué)者(或許一些老手)可能沒去搞懂的幾個(gè)概念:Hibernate、JPA、Spring Data JPA 之間的關(guān)聯(lián)。
嘿嘿,前段時(shí)間有位同學(xué)說(shuō)去大廠面試被問(wèn)了這個(gè)。
好了,話不多說(shuō),發(fā)車!
Hibernate
Hibernate 就不多介紹了, 一個(gè) ORM 框架,它提供了 HQL 來(lái)屏蔽底層不同數(shù)據(jù)庫(kù)廠商 SQL 之間的差異,大大提升了程序的可移植性。
也提供了一套 Criteria API 來(lái)進(jìn)行數(shù)據(jù)操作,使用這套 API 不需要關(guān)注底層 SQL 的實(shí)現(xiàn),直接操作 API 即可。
JPA
JPA 是一個(gè) Java 持久化規(guī)范,在 JDK 5 后提出的。
它的提出主要是為了整合市面上已有的 ORM 框架,如 Hibernate、EclipseLink 等。
官方覺得:你們搞框架可以,但是得按照我 Java 定的規(guī)矩來(lái)。
只有統(tǒng)一了接口,我們程序員使用的時(shí)候才會(huì)便捷。但它只是一個(gè)規(guī)范,具體實(shí)現(xiàn)還是由這些 ORM 框架來(lái)完成。
所以 JPA 的提出是為了屏蔽市面上各大 ORM 框架的差異,便于開發(fā)人員的使用。
Spring Data JPA:
雖然市面上很多 ORM 框架都實(shí)現(xiàn)了 JPA 規(guī)范,但它們基于 JPA 基礎(chǔ)又做了一些擴(kuò)展,這使得使用 JPA 的時(shí)候不能無(wú)縫切換底層的 ORM 框架。
所以 Spring 又提出了 Spring Data JPA 。
Spring Data JPA 符合 JPA 規(guī)范,但它是一個(gè)抽象層,上接 JPA 下接各大 ORM 框架,簡(jiǎn)化了持久層開發(fā)且屏蔽了各大 ORM 框架的差異,兩個(gè)字,舒服。
總結(jié)
JPA 是規(guī)范,統(tǒng)一了規(guī)范才便于使用。
Hibernate 是 ORM 框架,它是 JPA 這個(gè)規(guī)范的一個(gè)實(shí)現(xiàn)。
Spring Data JPA 則是 Spring 提出的,因?yàn)椴煌?ORM 框架雖說(shuō)有 JPA 規(guī)范約束,但是還是有不同的擴(kuò)展,不易無(wú)縫替換,所以基于 JPA 添加了一個(gè)抽象層,來(lái)屏蔽不同 ORM 框架的差距。
這其實(shí)類似于 Spring 自己定義一個(gè)標(biāo)準(zhǔn)來(lái)統(tǒng)一 Spring 對(duì)持久層的支持,這樣對(duì)于我們這些在 Spring 使用 ORM 框架的開發(fā)來(lái)說(shuō),不需要管底層 ORM 怎么變了。