带你搭一个SpringBoot+SpringData JPA的环境
前言
只有光頭才能變強。
文本已收錄至我的GitHub倉庫,歡迎Star:https://github.com/ZhongFuCheng3y/3y
不知道大家對SpringBoot和Spring Data JPA了解多少,如果你已經學過Spring和Hibernate的話,那么SpringBoot和SpringData JPA可以分分鐘上手的。SpringBoot和SpringData JPA的好處我就不說了,當時我學習的時候也粗略做過筆記,有興趣的同學可以去看看
- SpringBoot就是這么簡單
- SpringData JPA就是這么簡單
其實我在學完SpringBoot和SpringData JPA了之后,寫過一個小Demo,但一直沒發出來而已(懶)。而最近要寫畢業設計的一個管理模塊(CRUD),并且我又沒寫過相關SpringBoot和SpringData JPA的搭建教程,所以就誕生了這篇文章了。
一、從零搭建環境
本次我使用的是IDEA編輯器來搭建SpringBoot和Spring Data JPA環境
首先,我們在IDEA新建項目的時候,選擇Spring Initializr,然后next就行了。
然后填寫一些項目的資料(其實這些資料也無關緊要,自己看著填就好了),隨后點擊next
隨后在勾選的時候,我就隨手勾選了個LomBok(其他的沒勾選,反正后面我們可以在pom文件下配置嘛)。可以看出,本次SpringBoot的版本為2.1.3。
- 注:如果不太了解LomBok的同學,建議去搜一下。這是一個非常好用的插件,有了它我們可以不用寫繁瑣的set/get方法。記得:使用lomBok還需要在IDEA下安裝插件
然后IDEA就會幫我們創建出Maven管理下SpringBoot的項目啦,此時一般我們會指定自己的下載好的Maven,重寫它的settings.xml文件
然后Maven就一直在下載相關的依賴啊,必要的插件啊(我等了差不多10分鐘吧,這個時間可以去倒杯Java喝喝.haha),等Maven下載完之后,我們的項目就成了下面那個樣子了(注:原生的是application.properties文件的,我改了一下后綴,我比較喜歡yml格式的):
二、完善pom文件
現在pom文件只有SpringBoot和LomBok的依賴,想要完成CURD的功能,我們需要用到Spring Web模塊、Spring Data JPA以及MySQL驅動依賴,所以我們得在pom文件下加入這些依賴:
<!--Web必要的-->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency><!--spring data jpa-->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency><!-- MySQL的java驅動 -->
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId>
</dependency>
pom文件的完整依賴圖如下:
三、配置yml文件
既然我們用到了SpringData JPA和MySQL,我們得為其進行配置最基礎的信息。比如說數據庫的用戶名和密碼,相對應的庫,以及SpringData JAP的策略。
#服務端容器的配置
server:port: 8887#數據庫配置
spring:datasource:username: 填寫自己的password: 填寫自己的driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://填寫自己的機器:3306/填寫自己的庫?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC# JPA配置jpa:hibernate:ddl-auto: updateshow-sql: true# formatSQL得這樣寫properties:hibernate:format_sql: true yml文件完整圖如下:
數據庫的信息填寫成自己的就行了。
四、寫一個User實體
我畢業設計其中就有對用戶的管理,我們用戶實體設計如下(大家的當然可以跟我的不一樣了,我這只是樣例):
package com.zhongfucheng.example.demo.domain;import lombok.Data;
import org.hibernate.annotations.GenericGenerator;import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;
import java.io.Serializable;
import java.util.Date;/*** 存儲用戶的信息** @author ozc* @version 1.0*/
@Entity // jpa的注解,需要加
@Table(name = "table_user") // 指定數據庫的表名
@Data // lombok
public class User implements Serializable {@Id@GeneratedValue(generator = "system-uuid")@GenericGenerator(name = "system-uuid", strategy = "uuid")private String userId;private String userNickname;private String userPassword;private String userEmail;private Integer actiState;//激活成功與激活失敗常量public static final int ACTIVATION_SUCCESSFUL = 1;public static final int ACTIVATION_UNSUCCESSFUL = 0;private String actiCode;private Date tokenExptime;} 再補充一句:因為我們有了LomBok的Data注解,并且在IDEA已經下好的LomBok的插件,所以我們可以不用寫set、get方法。
User實體圖如下:
五、寫一個UserRepository
UserRepository是dao層的東西了,相當于UserDao/UserMapper,只是叫法不一樣而已。比如在Struts2喜歡將名字取成xxxAction,而在SpringMVC喜歡將名字取成xxxxController。
一般地,我們將UserRepository繼承JpaRepository就可以有對應的增刪改查方法:
import com.zhongfucheng.example.demo.domain.User;
import org.springframework.data.jpa.repository.JpaRepository;/*** UserDao 操作數據庫* @author ozc* @version 1.0*/
public interface UserRepository extends JpaRepository<User, String> {}
UserRepository圖如下:
ok,我們的UserRepository已經寫好了,至于為啥我們傳入<User, String>,點進去看一下就明白了:
六、寫一個UserService
我們就查user表所有的記錄出來就好了,代碼如下:
// 接口
public interface UserService {List<User> getAllUser();
}// 實現
@Service
public class UserServiceImpl implements UserService {@Autowiredprivate UserRepository userRepository;@Overridepublic List<User> getAllUser() {return userRepository.findAll();}
} UserService圖如下:
為啥會有findAll()方法?因為我們的UserRepository 繼承了JpaRepository
七、寫一個UserController
UserController調用一下service的方法,看是否能返回成功,如果能返回成功,那說明我們的環境已經是ok的了。
UserController代碼如下:
@RestController
public class UserController {@Autowiredprivate UserService userService;/*** 得到所有用戶*/@GetMapping(value = "/user", produces = {"application/json;charset=UTF-8"})public void getAllUser () {List<User> allUser = userService.getAllUser();for (User user : allUser) {System.out.println(user);}}
} Controller代碼圖如下:
八、測試一下看是否能返回數據
進入DemoApplication,右鍵,啟動我們的SpringBoot項目:
在瀏覽器輸入我們的url:http://localhost:8887/user。然后我們從后臺查看,打印出查詢的SQL語句,已經后臺已經打印表已有的記錄。
最后
我們可以發現使用SpringBoot+SpringData JPA的方式,不需要很多的配置,不需要很多的代碼就可以從數據庫中查找出數據了。非常適合我們做一些簡答的測試和小功能。如果對例子有疑問的同學應該是對SpringData JPA不太熟悉,建議去找找相關的教程看一下,相信你可以很快就入門了。
樂于輸出干貨的Java技術公眾號:Java3y。公眾號內有200多篇原創技術文章、海量視頻資源、精美腦圖,不妨來關注一下!
覺得我的文章寫得不錯,不妨點一下贊!
轉載于:https://www.cnblogs.com/Java3y/p/10583162.html
總結
以上是生活随笔為你收集整理的带你搭一个SpringBoot+SpringData JPA的环境的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第四周课上测试
- 下一篇: 沃尔沃s60le驱混动是什么意思?