日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Spring Boot2.x集成JPA快速開發的示例代碼

瀏覽:204日期:2023-09-04 17:10:24

什么是JPA

一種規范,并非ORM框架,也就是ORM上統一的規范

spring-boot-starter-data-jpa 是Spring Boot的項目,包含了spring-data-jpa和一些其他依賴用于Spring Boot項目 spring-data-jpa 是Spring Data的項目,就是本體,用于任何項目

解決

為了執行簡單查詢分頁,編寫太多重復代碼 基于JPA的數據訪問層的增強支持

用了之后可以做什么,為什么要用?如下代碼解釋

實體類

package com.example.springredis.entity;import lombok.Data;import javax.persistence.Entity;import javax.persistence.GeneratedValue;import javax.persistence.GenerationType;import javax.persistence.Id;import java.io.Serializable;@Entity@Datapublic class User implements Serializable { @Id @GeneratedValue(strategy = GenerationType.AUTO) private Long id; private String name; private String account; private String pwd;}

dao層

@Repositorypublic interface UserDao extends JpaRepository<User, Long> {}

測試類

@Autowired private UserDao userDao; public void findAllTest() { System.out.println(userDao.findAll().toString()); }

上面的操作已經完成了一個查詢全部,相信不用在做多余的解釋了

JPA優點:主要就是簡單易用,集成方便,可以不用寫SQL語句

準備工作

JDK 1.8 以上 IDEA 2020.3 Gradle 5+ 或者 Maven 3.5+ 在 https://start.spring.io/ 初始化一個項目

Spring Boot2.x集成JPA快速開發的示例代碼

這里使用的是Maven,下載之后請在IDEA導入項目

項目結構圖

Spring Boot2.x集成JPA快速開發的示例代碼

先看pom.xml配置

國外依賴下載慢,更換阿里源

<?xml version='1.0' encoding='UTF-8'?><project xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xmlns='http://maven.apache.org/POM/4.0.0' xsi:schemaLocation='http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd'> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.0.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>springboot-jpa</artifactId> <version>0.0.1-SNAPSHOT</version> <name>springboot-jpa</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> </properties> <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>com.h2database</groupId> <artifactId>h2</artifactId> <scope>runtime</scope> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> <repositories> <!--阿里云主倉庫,代理了maven central和jcenter倉庫--> <repository> <id>aliyun</id> <name>aliyun</name> <url>https://maven.aliyun.com/repository/public</url> <releases><enabled>true</enabled> </releases> <snapshots><enabled>false</enabled> </snapshots> </repository> <!--阿里云代理Spring 官方倉庫--> <repository> <id>spring-milestones</id> <name>Spring Milestones</name> <url>https://maven.aliyun.com/repository/spring</url> <releases><enabled>true</enabled> </releases> <snapshots><enabled>false</enabled> </snapshots> </repository> </repositories></project>

定義一個實體對象 SysUser.java

package com.example.demo.model;import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;import javax.persistence.Entity;import javax.persistence.GeneratedValue;import javax.persistence.GenerationType;import javax.persistence.Id;@Data@NoArgsConstructor@AllArgsConstructor@Entity(name = 'sys_user')public class SysUser { @Id @GeneratedValue(strategy = GenerationType.AUTO) private Long id; private String email; private String username; private String password; public SysUser(String email, String username, String password) { this.email = email; this.username = username; this.password = password; }} 這里有一個 **SysUser** 類, @NoArgsConstructor 默認構造函數僅為JPA而存在。 另一個構造函數是您將用于創建要保存到數據庫的user實例的構造函數。 在類上加 @Entity 注解,表示這個是一個 JPA 的實體,如果在類上沒有加 @Table 注解,表明該實體將映射到名為 sys_user 的表,如果要加上,可以在其 name 屬性里寫入表名,如: @Table(name = 't_user') id 屬性使用 @Id 注釋,以便JPA將其識別為對象的ID. @GeneratedValue(strategy = GenerationType.AUTO) 自增長ID策略

創建一個 UserRepository.java 接口

這里很簡單,直接繼承核心接口 JpaRepository

package com.example.demo.repository;import com.example.demo.model.SysUser;import org.springframework.data.jpa.repository.JpaRepository;import org.springframework.stereotype.Repository;@Repositorypublic interface UserRepository extends JpaRepository<SysUser, Long> {}

Spring Boot2.x集成JPA快速開發的示例代碼

配置文件application.yml

修改application.properties 為 application.yml

src/main/resources/application.yml

spring: datasource: driverClassName: org.h2.Driver password: root url: jdbc:h2:mem:demodb:file:data/demo username: root jpa: open-in-view: true database-platform: org.hibernate.dialect.H2Dialect # spring.jpa.show-sql=true 配置在日志中打印出執行的 SQL 語句信息。 show-sql: true # 配置指明在程序啟動的時候要刪除并且創建實體類對應的表。 # create 這個參數很危險,因為他會把對應的表刪除掉然后重建。所以千萬不要在生成環境中使用。只有在測試環境中,一開始初始化數據庫結構的時候才能使用一次。 # ddl-auto:create----每次運行該程序,沒有表格會新建表格,表內有數據會清空 # ddl-auto:create-drop----每次程序結束的時候會清空表 # ddl-auto:update----每次運行程序,沒有表格會新建表格,表內有數據不會清空,只會更新(推薦) # ddl-auto:validate----運行程序會校驗數據與數據庫的字段類型是否相同,不同會報錯 hibernate.ddl-auto: update

h2數據庫

在resources 文件夾下新建 data.sql

data.sql

DROP TABLE IF EXISTS sys_user;CREATE TABLE sys_user( id INT AUTO_INCREMENT PRIMARY KEY, email VARCHAR(250) DEFAULT NULL, username VARCHAR(250) NOT NULL, password VARCHAR(250) NOT NULL);

測試類進行測試 SpringbootJpaApplicationTests.java

package com.example.demo;import com.example.demo.model.SysUser;import com.example.demo.repository.UserRepository;import lombok.extern.slf4j.Slf4j;import org.junit.After;import org.junit.Before;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.context.junit4.SpringRunner;@Slf4j@RunWith(SpringRunner.class)@SpringBootTestpublic class SpringbootJpaApplicationTests { @Autowired private UserRepository userRepository; @Before public void add() { userRepository.save(new SysUser('123@qq.com', 'root', 'root')); } @Test public void contextLoads() { System.out.println(userRepository.findAll().toString()); } //修改操作 @After public void update() { // ifPresent 如果存在值,則使用值調用指定的使用者,否則不執行任何操作。 userRepository.findById(1L).ifPresent(user -> { user.setUsername('馬華云騰'); userRepository.save(user); System.out.println(user.toString()); }); } //刪除 @After public void del() { userRepository.findById(2L).ifPresent(user -> userRepository.delete(user)); }}

測試輸出

Spring Boot2.x集成JPA快速開發的示例代碼

常見異常

如果出現下列等錯誤:

Error:(41, 13) java: 找不到符號符號: 方法 setName(java.lang.String)位置: 類型為com.example.springbootjpademo.entity.User的變量 user

請注意下面的設置是否正確:

Spring Boot2.x集成JPA快速開發的示例代碼

RestClient API 測試

Spring Boot2.x集成JPA快速開發的示例代碼

### 新增1POST http://localhost:8080/user/addContent-Type: application/json{ 'email': 'eyck@aws.com', 'username': 'root', 'password': 'root'}### 新增2POST http://localhost:8080/user/addContent-Type: application/json{'email': 'ekko@aws.com','username': 'ekko','password': 'ekko'}### 修改PUT http://localhost:8080/user/updateContent-Type: application/json{ 'id': 1, 'email': 'eyck@aws.com', 'username': 'root', 'password': 'root'}### 獲取所有GET http://localhost:8080/user/allAccept: */*Cache-Control: no-cache### 刪除PUT http://localhost:8080/user/del/2### 獲取所有GET http://localhost:8080/user/allAccept: */*Cache-Control: no-cache

左上角 Run all ...

測試結果....

Spring Boot2.x集成JPA快速開發的示例代碼

代碼地址

https://github.com/Gleans/spring-boot/tree/master/springboot-jpa

到此這篇關于Spring Boot2.x集成JPA快速開發的文章就介紹到這了,更多相關Spring Boot2.x集成JPA快速開發內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品88久久久久久| 国模大尺度视频一区二区| 国产一二在线播放| 中文字幕高清在线播放| 久久狠狠婷婷| 亚洲欧洲一区二区天堂久久| 久久最新视频| 日韩欧乱色一区二区三区在线| 日本久久二区| 日本中文字幕一区二区视频| 国产欧美日韩精品一区二区三区| 国产精品毛片视频| 国内自拍视频一区二区三区| 久久狠狠婷婷| 日韩中文字幕不卡| 国产精品扒开腿做爽爽爽软件| sm久久捆绑调教精品一区| 久久在线电影| 日韩精品成人在线观看| 成人影视亚洲图片在线| 亚洲成人一区| 国产调教一区二区三区| 日韩理论视频| 亚洲影视一区二区三区| 精精国产xxxx视频在线播放| 久久久久97| 国产成人精品免费视| 亚洲国产综合在线看不卡| 日本午夜精品久久久| 高清在线一区| 亚洲涩涩av| 日本久久黄色| 亚洲永久精品唐人导航网址| 麻豆精品99| 精品91久久久久| 国产精品www.| 国产精品婷婷| 97欧美在线视频| 石原莉奈在线亚洲三区| 国产精品久久久久久久久久白浆 | 国产毛片久久| 久久久国产精品网站| 亚洲精品va| 精品视频一区二区三区在线观看| 不卡视频在线| 国内精品美女在线观看| 手机精品视频在线观看| 久久久久久一区二区| 亚洲2区在线| 久久亚洲成人| 国产欧美午夜| 在线午夜精品| 精品免费视频| 日本视频一区二区| 日韩亚洲在线| 欧美天堂视频| 国产精品视频一区二区三区综合| 亚洲女人av| 久久亚洲专区| 97人人精品| 国产精品黄色| 日韩 欧美一区二区三区| 伊人久久婷婷| 999国产精品永久免费视频app| 国产精品任我爽爆在线播放| 亚洲一区欧美| re久久精品视频| 高清一区二区三区| 国产精品色在线网站| 综合色就爱涩涩涩综合婷婷| 蜜桃tv一区二区三区| 桃色一区二区| 国产高潮在线| 成人高清一区| 久久精品毛片| 国产欧美自拍一区| 日韩国产欧美一区二区三区| 综合激情网站| 老牛影视一区二区三区| 九色精品91| 欧美日韩视频网站| 不卡专区在线| 国产精品成人一区二区不卡| 开心激情综合| 国产精品久久久久久久久久白浆 | 伊人www22综合色| 国产午夜精品一区二区三区欧美| 欧美影院三区| 99久久精品网| 激情五月色综合国产精品| 亚洲午夜一级| 99riav国产精品| 另类亚洲自拍| 亚洲日本国产| 日本午夜精品一区二区三区电影| 日本视频中文字幕一区二区三区| 人人爱人人干婷婷丁香亚洲| 久久精品999| 久久久精品区| 国产aⅴ精品一区二区四区| 国产精品网址| 久久这里只有精品一区二区| 精品国产不卡一区二区| 女生影院久久| 精品一区免费| 日韩中文字幕亚洲一区二区va在线| 亚洲综合中文| 国产精品一卡| 日韩国产在线| 亚洲欧美不卡| 日韩精品免费视频人成| 久久99精品久久久久久园产越南| 91中文字幕精品永久在线| 成人精品亚洲| 日韩中文字幕不卡| 亚州av一区| 精品久久网站| 激情婷婷欧美| 综合一区av| 美腿丝袜亚洲一区| 日韩中文在线电影| 玖玖玖国产精品| 欧美国产专区| 国精品一区二区三区| 亚洲精品九九| 精品视频一区二区三区在线观看 | 国产精品亚洲人成在99www| 日韩av一级片| 精品久久99| 999久久久国产精品| 久久午夜精品| 久久精品一区| 在线亚洲免费| 91精品在线免费视频| 精品免费视频| 九九综合在线| 日韩av一区二区三区| 黑人精品一区| 亚洲精品欧美| 国际精品欧美精品| 在线亚洲自拍| 国产精品一区高清| 日韩一区二区三区在线免费观看| 美女黄网久久| 高清一区二区三区av| 男人的天堂久久精品| 精品入口麻豆88视频| 国产亚洲精品v| 精品国产鲁一鲁****| 亚洲女人av| 中文字幕在线看片| 少妇精品久久久一区二区| 国产在视频一区二区三区吞精| 噜噜噜久久亚洲精品国产品小说| 精品国产乱码久久久久久1区2匹| 日韩精品一区第一页| 美女福利一区二区三区| 蜜臀久久久99精品久久久久久| 免费视频一区二区三区在线观看| 伊人久久大香线蕉av超碰演员| 国产精品午夜av| 在线视频精品| а√天堂8资源中文在线| 婷婷精品在线| 国产国产精品| 久久婷婷国产| 亚洲一区二区三区无吗| 成人国产精品一区二区免费麻豆| 亚洲制服一区| 亚洲高清不卡| 精品国产三区在线| 日韩三级一区| 欧美亚洲国产激情| 精品视频一区二区三区四区五区 | 伊人久久成人| 国产在线看片免费视频在线观看| 日韩av三区| 亚洲免费一区二区| 久久九九电影| 精品入口麻豆88视频| 人人爱人人干婷婷丁香亚洲| 国产伊人精品| 黄色aa久久| 精品五月天堂| 国产精品白丝一区二区三区| 日韩精品三区四区| 蜜桃免费网站一区二区三区| 欧美不卡视频| 久久蜜桃av| 色老板在线视频一区二区| 久久精品免视看国产成人| 国产日本精品| 婷婷综合电影| 亚洲精品动态| 蜜臀精品久久久久久蜜臀| 影院欧美亚洲| 91tv亚洲精品香蕉国产一区| 国产一区二区三区不卡视频网站| 国产欧美午夜| 国产精品久久久久9999高清|