学习Spring Boot,将整个过程记录下来,作为一个Step by Step的Tutorial教程吧。
这是第一篇,创建一个Web Application,使用Thymeleaf模板,基于JPA。
项目源码寄存在Github repo
开发环境
数据库
本案例中使用Microsoft SQL Server Express。呃,主要原因就是,当前我的电脑上已经安装有(随着Visual Studio安装的),就懒得再去安装额外的数据库系统了。
如果没有安装SQL Server Express,可以去SQL Server官网去下载,Express版本是免费的。
- Java SDK,版本选择了11(最新的一个LTS版本)。
- IDE: VS Code,自行下载。
- 版本管理,毫无疑问:Git。
- Maven的下载安装,详见Apache Maven 官网
创建程序
打开Spring Initalizer来创建初始程序:
下载压缩包,将该包解压到对应的目录下。
项目设置
更新POM
参考我之前《JDBC Driver to SQL Server Express》,POM文件需要更新以支持SQL Server。
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>mssql-jdbc</artifactId>
<version>10.2.1.jre11</version>
<scope>runtime</scope>
</dependency>
JPA相关的属性
至于,使用SQL Server Express,需要额外的配置才能正确使用。参考之前的文档。
设置JPA相关的属性(app.properties):
spring.datasource.driver-class-name=com.microsoft.sqlserver.jdbc.SQLServerDriver
spring.datasource.url=jdbc:sqlserver://localhost;database=library;integratedSecurity=true;encrypt=true;trustServerCertificate=true
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=update
项目实现
Model定义
这里创建一个Person Role(用户角色)的Model。
import javax.persistence.Column;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.persistence.Convert;
import javax.persistence.Entity;
import org.hibernate.annotations.Cache;
import org.hibernate.annotations.CacheConcurrencyStrategy;
import org.springframework.validation.annotation.Validated;
@Validated
@Entity
@Table(name = "person_role_def")
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
public class PersonRole {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Long id;
@Column(name="role_value", nullable = false, columnDefinition = "INT")
@Convert(converter = PersonRoleEnumConverter.class)
private PersonRoleEnum roleValue;
@Column(name="role_name", nullable = true, length = 50)
private String roleName;
public PersonRole