您当前的位置: 首页 >  spring boot

水的精神

暂无认证

  • 1浏览

    0关注

    711博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

Spring Boot (十五): Spring Boot + Jpa + Thymeleaf 增删改查示例

水的精神 发布时间:2019-06-08 08:36:49 ,浏览量:1

 

纯洁的微笑 Java极客技术 5月17日

文章介绍如何使用 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 的相关包引用

 
  1. org.springframework.boot

  2. spring-boot-starter-web

  3. org.springframework.boot

  4. spring-boot-starter-thymeleaf

  5. org.springframework.boot

  6. spring-boot-starter-data-jpa

  7. mysql

  8. mysql-connector-java

在application.properties中添加配置

 
  1. spring.datasource.url=jdbc:mysql://127.0.0.1/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC&useSSL=true

  2. spring.datasource.username=root

  3. spring.datasource.password=root

  4. spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

  5.  

  6. spring.jpa.properties.hibernate.hbm2ddl.auto=create

  7. spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect

  8. spring.jpa.show-sql= true

  9.  

  10. spring.thymeleaf.cache=false

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

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

启动类

启动类需要添加 Servlet 的支持

 
  1. @SpringBootApplication

  2. public class JpaThymeleafApplication extends SpringBootServletInitializer {

  3. @Override

  4. protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {

  5. return application.sources(JpaThymeleafApplication.class);

  6. }

  7.  

  8. public static void main(String[] args) throws Exception {

  9. SpringApplication.run(JpaThymeleafApplication.class, args);

  10. }

  11. }

数据库层代码

实体类映射数据库表

 
  1. @Entity

  2. public class User {

  3. @Id

  4. @GeneratedValue

  5. private long id;

  6. @Column(nullable = false, unique = true)

  7. private String userName;

  8. @Column(nullable = false)

  9. private String password;

  10. @Column(nullable = false)

  11. private int age;

  12. ...

  13. }

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

 
  1. public interface UserRepository extends JpaRepository {

  2. User findById(long id);

  3. Long deleteById(Long id);

  4. }

业务层处理

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

 
  1. @Service

  2. public class UserServiceImpl implements UserService{

  3.  

  4. @Autowired

  5. private UserRepository userRepository;

  6.  

  7. @Override

  8. public List getUserList() {

  9. return userRepository.findAll();

  10. }

  11.  

  12. @Override

  13. public User findUserById(long id) {

  14. return userRepository.findById(id);

  15. }

  16.  

  17. @Override

  18. public void save(User user) {

  19. userRepository.save(user);

  20. }

  21.  

  22. @Override

  23. public void edit(User user) {

  24. userRepository.save(user);

  25. }

  26.  

  27. @Override

  28. public void delete(long id) {

  29. userRepository.delete(id);

  30. }

  31. }

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

 
  1. @Controller

  2. public class UserController {

  3.  

  4. @Resource

  5. UserService userService;

  6.  

  7.  

  8. @RequestMapping("/")

  9. public String index() {

  10. return "redirect:/list";

  11. }

  12.  

  13. @RequestMapping("/list")

  14. public String list(Model model) {

  15. List users=userService.getUserList();

  16. model.addAttribute("users", users);

  17. return "user/list";

  18. }

  19.  

  20. @RequestMapping("/toAdd")

  21. public String toAdd() {

  22. return "user/userAdd";

  23. }

  24.  

  25. @RequestMapping("/add")

  26. public String add(User user) {

  27. userService.save(user);

  28. return "redirect:/list";

  29. }

  30.  

  31. @RequestMapping("/toEdit")

  32. public String toEdit(Model model,Long id) {

  33. User user=userService.findUserById(id);

  34. model.addAttribute("user", user);

  35. return "user/userEdit";

  36. }

  37.  

  38. @RequestMapping("/edit")

  39. public String edit(User user) {

  40. userService.edit(user);

  41. return "redirect:/list";

  42. }

  43.  

  44.  

  45. @RequestMapping("/delete")

  46. public String delete(Long id) {

  47. userService.delete(id);

  48. return "redirect:/list";

  49. }

  50. }

  • return"user/userEdit"; 代表会直接去 resources 目录下找相关的文件。

  • return"redirect:/list"; 代表转发到对应的 Controller,这个示例就相当于删除内容之后自动调整到 list 请求,然后再输出到页面。

页面内容

list 列表

 
  1. userList

  2. 用户列表

  3. #

  4. User Name

  5. Password

  6. Age

  7. Edit

  8. Delete

  9. 1

  10. neo

  11. Otto

  12. 6

  13. edit

  14. delete

  • add

  •  

  • 效果图:

    rth:each="user : ${users}"> 这里会从 Controler 层 model set 的对象去获取相关的内容, th:each表示会循环遍历对象内容。

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

    修改页面:

     
    1. user

    2. 修改用户

    3. userName

  • Password

  • age

  •      

  • Back

  •  

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

    效果图:

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

    文章内容已经升级到 Spring Boot 2.x

    示例代码-https://github.com/ityouknow/spring-boot-examples

    关注
    打赏
    1664074814
    查看更多评论

    最近更新

    热门博客

    立即登录/注册

    微信扫码登录

    0.0443s