第三章:springboot+jpa+thymeleaf增删改查示例

这一章介绍如何使用jpa和thymeleaf做一个增删改查的示例。

项目构建

在pom.xml中添加JPA、Thymeleaf等相关jar包的依赖。

<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>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <!--<scope>provided</scope>-->
        </dependency>

在application.properties中添加配置

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

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

#thymeleaf start
spring.thymeleaf.mode=HTML5
spring.thymeleaf.encoding=UTF-8
#开发时关闭缓存,不然没法看到实时页面,生产可配置为true
spring.thymeleaf.cache=false
#thymeleaf end

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

启动类

启动类需要添加Servlet的支持

@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);
    }
}
实体类

实体类映射数据库表

@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;

    public long getId() {
        return id;
    }
    public User setId(long id) {
        this.id = id;
        return this;
    }
    ......
UserRepository

继承JpaRepository类会自动实现很多内置的方法,包括增删改查。也可以根据方法名来自动生成相关sql。

public interface UserRepository extends JpaRepository<User, Long> {

    User findById(long id);
    void deleteById(Long id);

 }
业务层处理

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

@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(findUserById(id));
    }
}

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

@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";
    }
}
  • return “user/userEdit”; 代表会直接去resources目录下找相关的文件。
  • return “redirect:/list”; 代表转发到对应的controller,这个示例就相当于删除内容之后自动调整到list请求,然后再输出到页面。
前端页面
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8"/>
    <title>userList</title>
    <link rel="stylesheet" th:href="@{/css/bootstrap.css}"></link>
</head>
<body class="container">
<br/>
<h1>用户列表</h1>
<br/><br/>
<div class="with:80%">
    <table class="table table-hover">
        <thead>
        <tr>
            <th>#</th>
            <th>User Name</th>
            <th>Password</th>
            <th>Age</th>
            <th>Edit</th>
            <th>Delete</th>
        </tr>
        </thead>
        <tbody>
        <tr  th:each="user : ${users}">
            <th scope="row" th:text="${user.id}">1</th>
            <td th:text="${user.userName}">neo</td>
            <td th:text="${user.password}">Otto</td>
            <td th:text="${user.age}">6</td>
            <td><a th:href="@{/toEdit(id=${user.id})}">edit</a></td>
            <td><a th:href="@{/delete(id=${user.id})}">delete</a></td>
        </tr>
        </tbody>
    </table>
</div>
<div class="form-group">
    <div class="col-sm-2 control-label">
        <a href="/toAdd" th:href="@{/toAdd}" class="btn btn-info">add</a>
    </div>
</div>

</body>
</html>
效果图

这里写图片描述

这是一个比较复杂的问题,需要涉及到前端框架 layui 和 fullcalendar 以及后端框架 Spring Boot 和 JPA 的使用。我可以给你提供一些思路和代码片段供参考。 前端部分: 1. 在 HTML 页面中引入 layui 和 fullcalendar 的相关资源文件。 ```html <link rel="stylesheet" href="https://cdn.staticfile.org/layui/2.5.7/css/layui.css" /> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/fullcalendar/3.10.2/fullcalendar.min.css" /> <script src="https://cdn.staticfile.org/layui/2.5.7/layui.all.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.22.2/moment.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/fullcalendar/3.10.2/fullcalendar.min.js"></script> ``` 2. 在 HTML 页面中添加一个用于显示日历的 div 元素。 ```html <div id="calendar"></div> ``` 3. 在 JavaScript 中初始化 fullcalendar,并获取后端返回的日程列表数据。 ```javascript layui.use(['layer'], function() { var layer = layui.layer; $('#calendar').fullCalendar({ header: { left: 'prev,next today', center: 'title', right: 'month,agendaWeek,agendaDay' }, defaultView: 'month', editable: true, events: function(start, end, timezone, callback) { $.ajax({ url: '/events', type: 'GET', dataType: 'json', success: function(response) { var events = []; response.forEach(function(event) { events.push({ id: event.id, title: event.title, start: event.startTime, end: event.endTime }); }); callback(events); }, error: function() { layer.alert('获取日程列表失败'); } }); } }); }); ``` 4. 在 JavaScript 中添加一个用于弹出添加日程的表单的函数。 ```javascript function addEvent() { layer.open({ type: 1, title: '添加日程', content: $('#add-event-form'), area: ['500px', 'auto'], btn: ['保存', '取消'], yes: function(index, layero) { // 提交表单数据并保存日程 $.ajax({ url: '/events', type: 'POST', data: $('#add-event-form').serialize(), success: function() { $('#calendar').fullCalendar('refetchEvents'); layer.close(index); }, error: function() { layer.alert('添加日程失败'); } }); } }); } ``` 后端部分: 1. 创建一个实体类 Event,用于表示日程信息。 ```java @Entity public class Event { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String title; @Temporal(TemporalType.TIMESTAMP) private Date startTime; @Temporal(TemporalType.TIMESTAMP) private Date endTime; // 省略 getter 和 setter 方法 } ``` 2. 创建一个 EventRepository 接口,继承 JpaRepository,用于对 Event 实体进行增删改查操作。 ```java public interface EventRepository extends JpaRepository<Event, Long> { } ``` 3. 创建一个 EventController 类,用于处理前端请求。 ```java @RestController public class EventController { @Autowired private EventRepository eventRepository; @GetMapping("/events") public List<Event> list() { return eventRepository.findAll(); } @PostMapping("/events") public void add(@Valid Event event) { eventRepository.save(event); } @PutMapping("/events/{id}") public void update(@PathVariable Long id, @Valid Event event) { event.setId(id); eventRepository.save(event); } @DeleteMapping("/events/{id}") public void delete(@PathVariable Long id) { eventRepository.deleteById(id); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值