Spring Boot整合Spring Data Jpa代碼實(shí)例
一、Spring Data Jpa的簡(jiǎn)介
spring data:其實(shí)就是spring 提供的一個(gè)操作數(shù)據(jù)的框架。而spring data JPA 只是spring data 框架下的一個(gè)基于JPA標(biāo)準(zhǔn)操作數(shù)據(jù)的模塊。
spring data jpa :基于JPA的標(biāo)準(zhǔn)對(duì)數(shù)據(jù)進(jìn)行操作。簡(jiǎn)化操作持久層的代碼,只需要編寫接口就可以,不需要寫sql語句,甚至可以不用自己手動(dòng)創(chuàng)建數(shù)據(jù)庫表。
二、添加依賴
<!--添加springdatajpa的依賴-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
三、在項(xiàng)目中添加application.properties(或者application.yml)配置文件,添加數(shù)據(jù)源配置以及jpa的配置
以下兩種任意一種都可以,表達(dá)的意思是一樣的
a、application.properties配置文件
#DB Configuration spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1:3306/springboot spring.datasource.username=root spring.datasource.password=ROOT #JPA Configuration spring.jpa.database=MySQL spring.jpa.show-sql=true spring.jpa.generate-ddl=true
b、application.yml配置文件
spring: datasource: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://127.0.0.1:3306/springboot username: root password: ROOT jpa: database: mysql show-sql: true generate-ddl: true
四、添加實(shí)體類
注意
- @Entity:標(biāo)識(shí)這個(gè)實(shí)體類是一個(gè)JPA實(shí)體,告訴JPA在程序運(yùn)行的時(shí)候記得生成這個(gè)實(shí)體類所對(duì)應(yīng)的表~
- @Table(name="自定義的表名"):自定義設(shè)置這個(gè)實(shí)體類在數(shù)據(jù)庫所對(duì)應(yīng)的表名!
- @Id:表明哪一個(gè)屬性對(duì)應(yīng)表中的主鍵
- @GeneratedValue(strategy = GenerationType.IDENTITY):主鍵自增長(zhǎng),設(shè)置主鍵的生成策略,這種方式依賴于具體的數(shù)據(jù)庫,如果數(shù)據(jù)庫不支持自增主鍵,那么這個(gè)類型是沒法用的。
- @Column(name = "自定義字段名",length = "自定義長(zhǎng)度",nullable = "是否可以空",unique = "是否唯一",columnDefinition = "自定義該字段的類型和長(zhǎng)度")
表示對(duì)這個(gè)變量所對(duì)應(yīng)的字段名進(jìn)行一些個(gè)性化的設(shè)置,例如字段的名字,字段的長(zhǎng)度,是否為空和是否唯一等等設(shè)置。
package com.offcn.entity;
import javax.persistence.*;
@Entity
@Table(name = "user")//創(chuàng)建表
public class User {
@Id//標(biāo)識(shí)主鍵
@GeneratedValue(strategy = GenerationType.IDENTITY)//主鍵自增長(zhǎng)
private Integer id;
private String username;
private Integer age;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", age=" + age +
'}';
}
}
五、dao層添加接口
package com.offcn.dao;
import com.offcn.entity.User;
import org.springframework.data.jpa.repository.JpaRepository;
public interface UserDao extends JpaRepository<User,Integer> {
}

六、Controller層測(cè)試代碼
package com.offcn.controller;
import com.offcn.dao.UserDao;
import com.offcn.entity.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.Optional;
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserDao userDao;
//添加
@RequestMapping("/saveInfo")
public String saveInfo(){
User user = new User();
user.setAge(18);
user.setUsername("小明");
userDao.save(user);
return "success";
}
//查詢
@GetMapping("/getUsersById")
public User getUserById(){
User user = userDao.getOne(1);
return user;
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javax.validation.constraints注解使用
這篇文章主要介紹了javax.validation.constraints注解使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
Mybatis-plus配置分頁插件返回統(tǒng)一結(jié)果集
本文主要介紹了Mybatis-plus配置分頁插件返回統(tǒng)一結(jié)果集,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
淺談java中類名.class, class.forName(), getClass()的區(qū)別
下面小編就為大家?guī)硪黄獪\談java中類名.class, class.forName(), getClass()的區(qū)別。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05

