12.24 Spring Boot + Jpa + Thymeleaf 增删改查示例

这篇文章介绍如何使用 Jpa 和 Thymeleaf 做一个增删改查的示例。

先和大家聊聊我为什么喜欢写这种脚手架的项目,在我学习一门新技术的时候,总是想快速的搭建起一个 Demo 来试试它的效果,越简单越容易上手最好。在网上找相关资料的时候总是很麻烦,有的文章写的挺不错的但是没有源代码,有的有源代码但是文章介绍又不是很清楚,所在找资料的时候稍微有点费劲。因此在我学习 Spring Boot 的时候,会写一些最简单基本的示例项目,一方面方便其它朋友以最快的方式去了解,一方面如果我的项目需要用到相关技术的时候,直接在这个示例版本去改造或者集成就可以。

现在的技术博客有很多的流派,有的喜欢分析源码,有的倾向于底层原理,我最喜欢写这种小而美的示例,方便自己方便他人。

其实以前写过 Thymeleaf 和 Jpa 的相关文章: Spring Boot (四): Thymeleaf 使用详解和Spring Boot(五):Spring Data Jpa 的使用 里面的代码示例都给的云收藏的内容Favorites-web,云收藏的内容比较多,查找起来不是很方便,因此想重新整理一篇快速上手、简单的内容,来介绍 Jpa 和 Thymeleaf 的使用,也就是本文的内容。

这篇文章就不在介绍什么是 Jpa 、 Thymeleaf ,如果还不了解这些基本的概念,可以先移步前两篇相关文章。

快速上手

配置文件

pom 包配置

pom 包里面添加 Jpa 和 Thymeleaf 的相关包引用

<code><dependency>
<groupid>org.springframework.boot/<groupid>
<artifactid>spring-boot-starter-web/<artifactid>
/<dependency>
<dependency>
<groupid>org.springframework.boot/<groupid>
<artifactid>spring-boot-starter-thymeleaf/<artifactid>
/<dependency>
<dependency>
<groupid>org.springframework.boot/<groupid>
<artifactid>spring-boot-starter-data-jpa/<artifactid>
/<dependency>
<dependency>
<groupid>mysql/<groupid>
<artifactid>mysql-connector-java/<artifactid>
/<dependency>
/<code>

在application.properties中添加配置

<code>spring.datasource.url=jdbc:mysql://127.0.0.1/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC&useSSL=true
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

spring.jpa.properties.hibernate.hbm2ddl.auto=create
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
spring.jpa.show-sql= true

spring.thymeleaf.cache=false
/<code>

其中propertiesspring.thymeleaf.cache=false是关闭 Thymeleaf 的缓存,不然在开发过程中修改页面不会立刻生效需要重启,生产可配置为 true。

在项目 resources 目录下会有两个文件夹:static目录用于放置网站的静态内容如 css、js、图片;templates 目录用于放置项目使用的页面模板。

启动类

启动类需要添加 Servlet 的支持

<code>@SpringBootApplication
public class JpaThymeleafApplication extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(JpaThymeleafApplication.class);
}

public static void main(String[] args) throws Exception {
SpringApplication.run(JpaThymeleafApplication.class, args);
}
}
/<code>

数据库层代码

实体类映射数据库表

<code>@Entity
public class User {
@Id
@GeneratedValue
private long id;
@Column(nullable = false, unique = true)
private String userName;
@Column(nullable = false)
private String password;
@Column(nullable = false)
private int age;
...
}
/<code>

继承 JpaRepository 类会自动实现很多内置的方法,包括增删改查。也可以根据方法名来自动生成相关 Sql,具体可以参考: Spring Boot (五):Spring Data Jpa 的使用

<code>public interface UserRepository extends JpaRepository<user> {
User findById(long id);
Long deleteById(Long id);
}
/<user>/<code>

业务层处理

Service 调用 Jpa 实现相关的增删改查,实际项目中 Service 层处理具体的业务代码。

<code>@Service
public class UserServiceImpl implements UserService{

@Autowired
private UserRepository userRepository;

@Override
public List<user> getUserList() {
return userRepository.findAll();
}

@Override
public User findUserById(long id) {
return userRepository.findById(id);
}

@Override
public void save(User user) {
userRepository.save(user);
}

@Override
public void edit(User user) {
userRepository.save(user);
}

@Override
public void delete(long id) {
userRepository.delete(id);
}
}
/<user>/<code>

Controller 负责接收请求,处理完后将页面内容返回给前端。

<code>@Controller
public class UserController {

@Resource
UserService userService;


@RequestMapping("/")
public String index() {
return "redirect:/list";
}

@RequestMapping("/list")
public String list(Model model) {
List<user> users=userService.getUserList();
model.addAttribute("users", users);
return "user/list";
}

@RequestMapping("/toAdd")
public String toAdd() {
return "user/userAdd";
}

@RequestMapping("/add")
public String add(User user) {
userService.save(user);
return "redirect:/list";
}

@RequestMapping("/toEdit")
public String toEdit(Model model,Long id) {
User user=userService.findUserById(id);
model.addAttribute("user", user);
return "user/userEdit";
}

@RequestMapping("/edit")
public String edit(User user) {
userService.edit(user);
return "redirect:/list";
}


@RequestMapping("/delete")
public String delete(Long id) {
userService.delete(id);
return "redirect:/list";
}

}
/<user>/<code>
  • return "user/userEdit"; 代表会直接去 resources 目录下找相关的文件。
  • return "redirect:/list"; 代表转发到对应的 Controller,这个示例就相当于删除内容之后自动调整到 list 请求,然后再输出到页面。

页面内容

list 列表

<code>



<title>userList/<title>
<link>




用户列表






<table>
<thead>

#
User Name
Password

Age
Edit
Delete

/<thead>
<tbody>

1
neo
Otto
6



/<tbody>
/<table>









/<code>

效果图:

Spring Boot + Jpa + Thymeleaf 增删改查示例

这里会从 Controler 层 model set 的对象去获取相关的内容,th:each表示会循环遍历对象内容。

其实还有其它的写法,具体的语法内容可以参考这篇文章: Spring Boot (四): Thymeleaf 使用详解

修改页面:

<code>



<title>user/<title>
<link>




修改用户










/<code>

添加页面和修改类似就不在贴代码了。

效果图:

Spring Boot + Jpa + Thymeleaf 增删改查示例

这样一个使用 Jpa 和 Thymeleaf 的增删改查示例就完成了。

"


分享到:


相關文章: