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

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

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

瀏覽:205日期: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久久久久久| 中文字幕成在线观看| 国产一区二区三区视频在线| 麻豆91在线播放| 精品一区二区三区在线观看视频| 久久久国产精品网站| 精品资源在线| 国产精品xx| 电影亚洲精品噜噜在线观看| 日本欧美不卡| 激情欧美国产欧美| 亚洲高清二区| 亚洲第一精品影视| 亚洲欧美日韩国产综合精品二区| 亚洲一区欧美二区| 四虎精品永久免费| 国产欧美午夜| 国产一区二区三区黄网站| 日韩av免费大片| 久久蜜桃av| 模特精品在线| 婷婷亚洲精品| 久久精品国产999大香线蕉| 国产一区2区| 久久亚洲专区| 亚洲另类视频| 欧美黄色一区| а√天堂中文在线资源8| 伊人精品一区| 日韩中文字幕| 精品精品99| 久久蜜桃精品| 日韩中文字幕91| 久久gogo国模啪啪裸体| 成人精品中文字幕| 蜜桃av一区二区在线观看| 国产精品午夜av| av综合电影网站| 天堂成人免费av电影一区| 国产精品一站二站| 欧洲一区二区三区精品| 久久福利一区| 日韩av一二三| 日韩免费高清| 日韩中出av| 天堂日韩电影| 欧美日本三区| 亚洲网站视频| 国产亚洲一区二区三区不卡| 欧洲av一区二区| 日韩成人午夜精品| 日韩欧美国产精品综合嫩v| 欧美综合二区| 精品久久久久久久| 免费在线观看精品| 国产一区国产二区国产三区 | 91精品国产调教在线观看| 亚洲精品在线a| 中文字幕在线看片| 日韩精品导航| 成人久久一区| 国产精品亚洲欧美日韩一区在线| 亚洲婷婷免费| 美女性感视频久久| 久久电影一区| 日韩高清不卡| 久久av日韩| 石原莉奈在线亚洲二区| 福利一区视频| 日本综合精品一区| 国产一区欧美| 久久亚洲精品中文字幕| 男人的天堂久久精品| 国产精品精品| 日本精品一区二区三区在线观看视频| 啪啪国产精品| 国产精品白丝久久av网站| 99香蕉国产精品偷在线观看 | 中文无码日韩欧| 999国产精品永久免费视频app| 日本不卡高清| 黄色成人在线网址| 免费看av不卡| 国产精品videossex久久发布 | 老牛国内精品亚洲成av人片| 亚洲天堂免费| 亚洲五月婷婷| 日本综合字幕| 精品国产欧美日韩一区二区三区| 青草久久视频| 亚州精品视频| 性一交一乱一区二区洋洋av| 欧洲一区二区三区精品| 国产九一精品| 日本中文字幕视频一区| 一区福利视频| 久久久精品久久久久久96| 国内揄拍国内精品久久| 国产精品天堂蜜av在线播放| 日本亚洲不卡| 亚洲专区欧美专区| 欧美sss在线视频| 97精品国产一区二区三区| 国产精品亚洲一区二区在线观看 | 你懂的国产精品永久在线| 三级一区在线视频先锋| 午夜国产欧美理论在线播放| 人人精品亚洲| 成人小电影网站| 精品精品国产三级a∨在线| 国产九九精品| 青青伊人久久| 日韩1区2区日韩1区2区| 日韩欧美中文字幕一区二区三区| 亚洲色图网站| 蜜臀精品久久久久久蜜臀| 久久福利一区| 日韩专区一卡二卡| 老牛国产精品一区的观看方式| 在线视频亚洲| 国产精品外国| 国产视频一区三区| 亚洲综合二区| 亚洲永久字幕| 国产一区二区精品| 久久成人亚洲| 亚洲天堂免费| 清纯唯美亚洲综合一区| 国产精品一区二区三区www| 国产三级精品三级在线观看国产| 欧美亚洲福利| 国产精品密蕾丝视频下载| 国产精品久久| 久久久91麻豆精品国产一区| 欧美国产视频| 国产精品jk白丝蜜臀av小说| 三级欧美韩日大片在线看| 亚洲三级精品| 亚洲精品护士| 少妇精品在线| 欧美片网站免费| 国产日本久久| 精品中文字幕一区二区三区 | 欧美日韩一区二区三区不卡视频 | 日本a口亚洲| 国产精品网在线观看| 精品美女在线视频| 桃色av一区二区| 日本精品影院| 久久亚洲影院| 国产精品白丝久久av网站| 麻豆视频在线看| 激情综合亚洲| 国产亚洲一级| 国产欧美精品久久| 国产精品国产一区| 欧美理论视频| 91麻豆精品激情在线观看最新| 精品国产成人| 五月天久久777| 日本成人一区二区| 国产亚洲第一伦理第一区| 成午夜精品一区二区三区软件| 国产精品成人a在线观看| 99久久精品网站| 一本综合精品| 国产精品九九| av亚洲在线观看| 日韩精品亚洲专区| 精品中文字幕一区二区三区四区| 日韩成人高清| 日本一区免费网站| 成人美女视频| 亚洲理论在线| 精品国产免费人成网站| 视频一区欧美日韩| 国产aa精品| 中文字幕亚洲影视| 黄色欧美在线| 视频在线在亚洲| 国产在线视频欧美一区| av不卡免费看| 精品深夜福利视频| 欧美日韩四区| 久久狠狠亚洲综合| 久久伦理在线| 国产精品任我爽爆在线播放| 1024精品一区二区三区| 国产精品探花在线观看| 欧美日韩日本国产亚洲在线| 蜜桃精品视频| 性色一区二区| 中文在线免费视频| 亚洲精品视频一二三区| 91偷拍一区二区三区精品| 涩涩涩久久久成人精品| 香蕉精品久久| 久久99精品久久久久久园产越南| 久色成人在线|