Spring Boot 系列(九)數(shù)據(jù)層-集成Spring-data-jpa

實(shí)際開發(fā)中熏矿,不可避免地會(huì)對(duì)數(shù)據(jù)進(jìn)行反復(fù)的增刪改查操作,然而這部分工作是十分繁瑣枯燥的。那么票编,隨即而生的ORM框架就能很好的解決這個(gè)問(wèn)題褪储。
我們常用的ORM框架有:Hibernate、Mybatis栏妖、Jpa 等乱豆。本文介紹SpringBoot 中集成 Jpa 框架奖恰。

集成 JPA (Java Persistence API) 吊趾,持久層框架。

Spring-data-jpa 依賴于 Hibernate瑟啃,對(duì)Hibernate有一定的了解有助于使用JPA框架论泛。

一、pom.xml添加依賴

<!-- mysql數(shù)據(jù)庫(kù)驅(qū)動(dòng) -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.21</version>
</dependency>

<!-- 數(shù)據(jù)層 Spring-data-jpa -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
查看spring-boot-starter-data-jpa的具體依賴蛹屿,可以發(fā)現(xiàn)有依賴hibernate

二屁奏、配置數(shù)據(jù)庫(kù)連接信息

#數(shù)據(jù)庫(kù)配置
spring.datasource.url=jdbc:mysql://localhost:3306/springboot
spring.datasource.username=root
spring.datasource.password=
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.jpa.properties.hibernate.hbm2ddl.auto=update
如果你熟悉hibernate,那么會(huì)清楚spring.jpa.properties.hibernate.hbm2ddl.auto 的作用
# 配置指定對(duì)數(shù)據(jù)庫(kù)表結(jié)構(gòu)的處理方式错负,值有:create坟瓢、create-drop、update犹撒、validate 
#
# create:每次加載hibernate的時(shí)候折联,都會(huì)重新根據(jù)模型生成表。如果表已存在识颊,會(huì)先刪除該表再生成诚镰。
# create-drop:?jiǎn)?dòng)項(xiàng)目加載hibernate的時(shí)候,會(huì)生成表祥款。停止項(xiàng)目時(shí)清笨,會(huì)把生成的表刪除掉。
# update:常用屬性刃跛。每次加載hibernate的時(shí)候抠艾,會(huì)生成表。如果表存在桨昙,會(huì)根據(jù)模型的屬性變化來(lái)更新表結(jié)構(gòu)检号,這個(gè)過(guò)程不會(huì)做刪表處理。
# validate:每次加載hibernate的時(shí)候绊率,會(huì)檢查表結(jié)構(gòu)谨敛,但不會(huì)生成表。

三滤否、創(chuàng)建實(shí)體類脸狸,并使用注解進(jìn)行映射。

package com.sam.demo.domain;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;

/**
 * @author sam
 * @since 2017/7/18
 */
@Entity
@Table(name = "t_person")  //指定表名
public class Person {

    @Id
    @GeneratedValue
    private Long id;

    @Column(nullable = false)
    private String name;

    @Column
    private int age;

    // getter & setter
}

四、創(chuàng)建 PersonRepository 接口 繼承 JpaRepository

package com.sam.demo.repository;

import com.sam.demo.domain.Person;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;

/**
 * @author sam
 * @since 2017/7/18
 */
public interface PersonRepository extends JpaRepository<Person, Long> {

    Person findByName(String name);

    Person findByNameAndAge(String name, int age);

    @Query("FROM Person p WHERE p.id=:id")
    Person findPersonById(@Param("id") Long id);

}

PersonRepository 繼承了 jpa提供的 JpaRepository炊甲。查看JpaRepository可以發(fā)現(xiàn)泥彤,已經(jīng)封裝好了基本的增刪改查操作,直接使用即可卿啡。
JpaRepository.png
除了默認(rèn)提供的增刪改成之外吟吝,jpa 還提供了極其簡(jiǎn)便的方式來(lái)自定義查詢等方法(不需要編寫任何sql語(yǔ)句):
如上面的 Person findByName(String name) 方法,JPA 會(huì)根據(jù)方法名(駝峰式)颈娜,解析出相應(yīng)的sql語(yǔ)句進(jìn)行具體的查詢操作剑逃。
當(dāng)我們需要執(zhí)行復(fù)雜的語(yǔ)句的時(shí)候,我們還可以使用 @Query() 創(chuàng)建自定義sql語(yǔ)句查詢:
@Query("FROM Person p WHERE p.id=:id")官辽,查詢語(yǔ)句與hibernate的HQL語(yǔ)句相同蛹磺,可以通過(guò) :id 來(lái)綁定 @Param("id") 的參數(shù)。

五同仆、controller 中使用 PersonRepository

package com.sam.demo.controller;

import com.sam.demo.domain.Person;
import com.sam.demo.repository.PersonRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

/**
 * @author sam
 * @since 2017/7/16
 */
@RequestMapping("/person")
@RestController
public class PersonController {

    @Autowired
    private PersonRepository personRepository;

    @RequestMapping(method = RequestMethod.GET)
    public Person index() {

        Person person = new Person();
        person.setName("sam");
        person.setAge(25);

        //保存person
        personRepository.save(person);

//        Person temp = personRepository.findPerson(1l);
        Person temp = personRepository.findByName("sam");

        return temp;
    }

}

訪問(wèn):http://localhost:8080/person 正確返回:
{"id":1,"name":"sam","age":25}
到此萤捆,基本完成了Spring Boot 集成 Spring-data-jpa 框架。
Spring-data-jpa 詳細(xì)使用請(qǐng)參考:Spring Data JPA 官方文檔

版權(quán)聲明:本文為博主原創(chuàng)文章俗批,轉(zhuǎn)載請(qǐng)注明出處俗或。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市岁忘,隨后出現(xiàn)的幾起案子辛慰,更是在濱河造成了極大的恐慌,老刑警劉巖臭觉,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件昆雀,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡蝠筑,警方通過(guò)查閱死者的電腦和手機(jī)狞膘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)什乙,“玉大人挽封,你說(shuō)我怎么就攤上這事〕剂停” “怎么了辅愿?”我有些...
    開封第一講書人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)忆某。 經(jīng)常有香客問(wèn)我点待,道長(zhǎng),這世上最難降的妖魔是什么弃舒? 我笑而不...
    開封第一講書人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任癞埠,我火速辦了婚禮状原,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘苗踪。我一直安慰自己颠区,他們只是感情好毕莱,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開白布质和。 她就那樣靜靜地躺著厦酬,像睡著了一般昌讲。 火紅的嫁衣襯著肌膚如雪短绸。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評(píng)論 1 289
  • 那天抗斤,我揣著相機(jī)與錄音龙宏,去河邊找鬼。 笑死秸歧,一個(gè)胖子當(dāng)著我的面吹牛今布,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播纷闺,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼份蝴,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼犁功!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起婚夫,我...
    開封第一講書人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤浸卦,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后案糙,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體限嫌,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年时捌,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了怒医。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡匣椰,死狀恐怖裆熙,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情禽笑,我是刑警寧澤入录,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站佳镜,受9級(jí)特大地震影響僚稿,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蟀伸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一蚀同、第九天 我趴在偏房一處隱蔽的房頂上張望缅刽。 院中可真熱鬧,春花似錦蠢络、人聲如沸衰猛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)啡省。三九已至,卻和暖如春髓霞,著一層夾襖步出監(jiān)牢的瞬間卦睹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工方库, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留结序,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓纵潦,卻偏偏與公主長(zhǎng)得像徐鹤,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子酪穿,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容