SpringBoot 整合SpringDataJPA

一汁果、引言

  • 什么是SpringDataJPA?
    Spring Data JPA能干什么
    可以極大的簡化JPA的寫法证芭,可以在幾乎不用寫實(shí)現(xiàn)的情況下,實(shí)現(xiàn)對(duì)數(shù)據(jù)的訪問和操作。除了CRUD外,還包括如分頁朋魔、排序等一些常用的功能扇雕。
    首先我們需要清楚的是Spring Data是一個(gè)開源框架值骇,在這個(gè)框架中Spring Data JPA只是這個(gè)框架中的一個(gè)模塊蜜徽,所以名稱才叫Spring Data JPA盆色。如果單獨(dú)使用JPA開發(fā),你會(huì)發(fā)現(xiàn)這個(gè)代碼量和使用JDBC開發(fā)一樣有點(diǎn)煩人组力,所以Spring Data JPA的出現(xiàn)就是為了簡化JPA的寫法,讓你只需要編寫一個(gè)接口繼承一個(gè)類就能實(shí)現(xiàn)CRUD操作了伐弹。
  • JPA/Hibernate關(guān)系蔓腐?
    JPA是一種規(guī)范,而Hibernate是它的一種實(shí)現(xiàn)龄句。除了Hibernate葬燎,還有EclipseLink(曾經(jīng)的toplink)岳遥,OpenJPA等可供選擇,所以使用Jpa的一個(gè)好處是认轨,可以更換實(shí)現(xiàn)而不必改動(dòng)太多代碼衷恭。

二倦炒、Demo實(shí)現(xiàn)

(1) 依賴引入遂唧,這里使用 druid 數(shù)據(jù)源
<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <version>1.4.1.RELEASE</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/com.alibaba/druid -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.0.29</version>
        </dependency>
(2)包結(jié)構(gòu)如下
目錄結(jié)構(gòu)
(3)配置
server:
  port: 9090
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    username: root
    password: root
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3308/user_test?useUnicode=true&useSSL=false&amp;characterEncoding=UTF-8

    #配置監(jiān)控統(tǒng)計(jì)攔截的 filters,去掉后監(jiān)控界面sql無法統(tǒng)計(jì)闷愤,'wall'用于防火墻
    filters: stat, wall
    #最大活躍數(shù)
    maxActive: 20
    #初始化數(shù)量
    initialSize: 1
    #最大連接等待超時(shí)時(shí)間
    maxWait: 60000
    #打開PSCache,并且指定每個(gè)連接PSCache的大小
    poolPreparedStatements: true
    maxPoolPreparedStatementPerConnectionSize: 20
    #通過connectionProperties屬性來打開mergeSql功能;慢SQL記錄
    #connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
    minIdle: 1
    timeBetweenEvictionRunsMillis: 60000
    minEvictableIdleTimeMillis: 300000
    validationQuery: select 1 from dual
    testWhileIdle: true
    testOnBorrow: false
    testOnReturn: false

jpa:
  # Specify the DBMS
  database: MySQL
  # Show or not log for each sql query
  show-sql: true
  format_sql: true
  hibernate:
  # Hibernate ddl auto (create, create-drop, update)
   ddl-auto: update
  # Naming strategy
  #[org.hibernate.cfg.ImprovedNamingStrategy  #org.hibernate.cfg.DefaultNamingStrategy]
   naming_strategy: org.hibernate.cfg.ImprovedNamingStrategy
  # stripped before adding them to the entity manager)
   dialect: org.hibernate.dialect.MySQL5Dialect
(3)配置

repository接口層

public interface UserDao extends
        JpaRepository<User,Long>,
        JpaSpecificationExecutor<User>,
        Serializable {
}

service層

/**
 * @author liyao
 * @createTime 2018/8/13
 * @description
 */
@Service
@Transactional
public class UserService {

    @Autowired
    private UserDao userDao;

    /**
     * 保存數(shù)據(jù)
     * @param user
     */
    public User save(User user){
        return userDao.save(user);
    }

    /**
     * 刪除數(shù)據(jù)
     * @param id
     * @return
     */
    public  List<User> delete(Long id){
        userDao.deleteById(id);
        return userDao.findAll();
    }

    /**
     * 查詢數(shù)據(jù)
     * @return
     */
    public List<User> list(){
        return userDao.findAll();
    }
}

controller層

@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserService userService;

    /**
     * 查詢用戶列表
     * @return
     */
    @GetMapping(value = "/list")
    public List<User> list(){
        return userService.list();
    }

    /**
     * 添加赢赊、更新用戶的方法
     * @param entity
     * @return
     */
    @GetMapping(value = "/save")
    public User save(User entity){
        return userService.save(entity);
    }

    /**
     * 刪除用戶
     * @param id
     * @return
     */
    @GetMapping(value = "/delete")
    public List<User> delete(Long id){
        userService.delete(id);
        return userService.list();
    }

}
(4)測(cè)試

1熏纯、新增
添加

2、查詢
查詢

3、刪除id=2
刪除

刪除之后查詢
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末贾惦,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌糜俗,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件象对,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡邮利,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來烁巫,“玉大人,你說我怎么就攤上這事违崇∫嗲福” “怎么了?”我有些...
    開封第一講書人閱讀 165,747評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵渗钉,是天一觀的道長。 經(jīng)常有香客問我子寓,道長,這世上最難降的妖魔是什么贝奇? 我笑而不...
    開封第一講書人閱讀 58,939評(píng)論 1 295
  • 正文 為了忘掉前任虹菲,我火速辦了婚禮,結(jié)果婚禮上掉瞳,老公的妹妹穿的比我還像新娘毕源。我一直安慰自己,他們只是感情好陕习,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評(píng)論 6 392
  • 文/花漫 我一把揭開白布霎褐。 她就那樣靜靜地躺著,像睡著了一般该镣。 火紅的嫁衣襯著肌膚如雪冻璃。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,737評(píng)論 1 305
  • 那天损合,我揣著相機(jī)與錄音省艳,去河邊找鬼。 笑死嫁审,一個(gè)胖子當(dāng)著我的面吹牛跋炕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播律适,決...
    沈念sama閱讀 40,448評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼辐烂,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼遏插!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起棉圈,我...
    開封第一講書人閱讀 39,352評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤涩堤,失蹤者是張志新(化名)和其女友劉穎眷蜓,沒想到半個(gè)月后分瘾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,834評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡吁系,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評(píng)論 3 338
  • 正文 我和宋清朗相戀三年德召,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片汽纤。...
    茶點(diǎn)故事閱讀 40,133評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡上岗,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蕴坪,到底是詐尸還是另有隱情肴掷,我是刑警寧澤,帶...
    沈念sama閱讀 35,815評(píng)論 5 346
  • 正文 年R本政府宣布背传,位于F島的核電站呆瞻,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏径玖。R本人自食惡果不足惜痴脾,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望梳星。 院中可真熱鬧赞赖,春花似錦、人聲如沸冤灾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽韵吨。三九已至匿垄,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間学赛,已是汗流浹背年堆。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留盏浇,地道東北人变丧。 一個(gè)月前我還...
    沈念sama閱讀 48,398評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像绢掰,于是被迫代替她去往敵國和親痒蓬。 傳聞我的和親對(duì)象是個(gè)殘疾皇子童擎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評(píng)論 2 355

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

  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,823評(píng)論 6 342
  • 1、通過CocoaPods安裝項(xiàng)目名稱項(xiàng)目信息 AFNetworking網(wǎng)絡(luò)請(qǐng)求組件 FMDB本地?cái)?shù)據(jù)庫組件 SD...
    陽明先生_X自主閱讀 15,982評(píng)論 3 119
  • 宮雨 二嘎娘接二嘎放學(xué)回到家攻晒,嘎娃說:“我都出汗了顾复。” 嘎娘說:“出汗鲁捏,還非得穿你爸的長褲芯砸?” 嘎娃:“不是天熱,...
    a宮雨閱讀 180評(píng)論 0 2
  • 愛情有時(shí)甜蜜,有時(shí)又痛苦动羽,只有在經(jīng)歷過重重困苦才能走向未來的幸福包帚。 愛情有時(shí)像在等公交車,不想坐的公交車接二連三頻...
    夢(mèng)之黎明閱讀 648評(píng)論 0 1
  • 本文章轉(zhuǎn)載于搜狗測(cè)試 應(yīng)用管理 所有應(yīng)用 系統(tǒng)應(yīng)用 第三方應(yīng)用 包名包含某字符串的應(yīng)用 查看應(yīng)用列表 安裝 APK...
    夜境閱讀 2,827評(píng)論 0 1