springboot整合jpa

1.先來看一下項(xiàng)目的目錄結(jié)構(gòu)

jpa1.jpg

2.在整合之前我們要在pom.xml中添加上依賴

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.0.28</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.48</version>
        </dependency>

3.加上了必要的依賴后我們就要在application.properties進(jìn)行丁配置

#配置數(shù)據(jù)源
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=tiger
spring.datasource.url=jdbc:mysql://localhost:3306/jpa
#相當(dāng)于數(shù)據(jù)庫方言
spring.jpa.database=mysql
#是否顯示sql語句
spring.jpa.show-sql=true
#格式化sql語句
spring.jpa.properties.hibernate.format_sql=true
spring.jpa.hibernate.ddl-auto=update

4.實(shí)體類代碼如下

package com.it.entity;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import javax.persistence.*;

@Data
@Entity
@NoArgsConstructor
@AllArgsConstructor
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "user_id")
    private int userId;
    @Column(name = "user_name",length = 20,unique = true,nullable = false)
    private String userName;

    @Column(name = "password",length = 20,nullable = false)
    private String password;

    private String addr;
}

5.下面是dao層代碼

package com.it.dao;

import com.it.entity.User;
import org.springframework.data.jpa.repository.JpaRepository;

import java.io.Serializable;
import java.util.List;

public interface IUserDao extends JpaRepository<User, Serializable> {
    List<User> findByPassword(String password);
}

6.service層代碼

package com.it.service;

import com.it.entity.User;

import java.util.List;

public interface IUserService {
    List<User> getAllUsers();

    void saveUsers(User user);
    List<User> findByPassword(String password);
}
package com.it.service.impl;

import com.it.dao.IUserDao;
import com.it.entity.User;
import com.it.service.IUserService;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;
import java.util.List;

@Service
public class UserServiceImpl implements IUserService {
    @Resource
    private IUserDao userDao;
    @Override
    public List<User> getAllUsers() {
        return userDao.findAll();
    }

    @Override
    public void saveUsers(User user) {
        userDao.saveAndFlush(user);
    }

    @Override
    public List<User> findByPassword(String password) {
        return userDao.findByPassword(password);
    }
}

7.測式代碼如下

package com.it.service;

import com.it.entity.User;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest
public class TestUserService {
   @Resource
   private IUserService userService;
   @Test
   public void testSaveUser(){
       User user = new User(0,"wen","tiger","安徽安慶");
       userService.saveUsers(user);
   }

   @Test
   public void findUserByPassword(){
       List<User> tiger = userService.findByPassword("tiger");
       System.out.println(tiger);
   }
}

我這里給出了findUserByPassword()測試方法的在控制臺(tái)打印出來的sql,如果你不在application.properties配置文件中加入spring.jpa.properties.hibernate.format_sql=true就不會(huì)像下面一樣格式.會(huì)顯示在一行,這樣不方便查看.

Hibernate: 
    select
        user0_.user_id as user_id1_0_,
        user0_.addr as addr2_0_,
        user0_.password as password3_0_,
        user0_.user_name as user_nam4_0_ 
    from
        user user0_ 
    where
        user0_.password=?
[User(userId=2, userName=wen, password=tiger, addr=安徽安慶)]
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末庸疾,一起剝皮案震驚了整個(gè)濱河市崩泡,隨后出現(xiàn)的幾起案子企孩,更是在濱河造成了極大的恐慌页藻,老刑警劉巖秘狞,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件病附,死亡現(xiàn)場離奇詭異闯传,居然都是意外死亡殿漠,警方通過查閱死者的電腦和手機(jī)赴精,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來绞幌,“玉大人蕾哟,你說我怎么就攤上這事×” “怎么了谭确?”我有些...
    開封第一講書人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長票渠。 經(jīng)常有香客問我逐哈,道長,這世上最難降的妖魔是什么问顷? 我笑而不...
    開封第一講書人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任昂秃,我火速辦了婚禮,結(jié)果婚禮上杜窄,老公的妹妹穿的比我還像新娘肠骆。我一直安慰自己,他們只是感情好塞耕,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開白布蚀腿。 她就那樣靜靜地躺著,像睡著了一般荷科。 火紅的嫁衣襯著肌膚如雪唯咬。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,262評(píng)論 1 308
  • 那天畏浆,我揣著相機(jī)與錄音胆胰,去河邊找鬼。 笑死刻获,一個(gè)胖子當(dāng)著我的面吹牛蜀涨,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼厚柳,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼氧枣!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起别垮,我...
    開封第一講書人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤便监,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后碳想,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體烧董,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年胧奔,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了逊移。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡龙填,死狀恐怖胳泉,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情岩遗,我是刑警寧澤扇商,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站宿礁,受9級(jí)特大地震影響钳吟,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜窘拯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望坝茎。 院中可真熱鬧涤姊,春花似錦、人聲如沸嗤放。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽次酌。三九已至恨课,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間岳服,已是汗流浹背剂公。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留吊宋,地道東北人纲辽。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親拖吼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子鳞上,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

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