Springboot使用jdbc以及事务支持

时间:2022-06-12 03:50:46

1.依赖

Springboot使用jdbc以及事务支持Springboot使用jdbc以及事务支持
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
View Code

2.配置属性

Springboot使用jdbc以及事务支持Springboot使用jdbc以及事务支持
spring.datasource.url=jdbc:mysql://localhost:3306/demo?serverTimezone=UTC
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.username=ivy
spring.datasource.password=*******
View Code

3.数据表结构

Springboot使用jdbc以及事务支持Springboot使用jdbc以及事务支持
CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `age` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8
View Code

4.项目结构

Springboot使用jdbc以及事务支持

 

 

5.源码

(1).Domain

Springboot使用jdbc以及事务支持Springboot使用jdbc以及事务支持
package com.example.demo.jdbc_tx.domain;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
    private Integer id;

    private String name;

    private Integer age;

    public User(String name, int age) {
        this.name = name;
        this.age = age;
    }
}
View Code

(2).Mapper

Springboot使用jdbc以及事务支持Springboot使用jdbc以及事务支持
package com.example.demo.jdbc_tx.mapper;


import com.example.demo.jdbc_tx.domain.User;
import org.springframework.jdbc.core.RowMapper;

import java.sql.ResultSet;
import java.sql.SQLException;

public class UserMapper implements RowMapper {
    @Override
    public Object mapRow(ResultSet resultSet, int i) throws SQLException {
        return new User(resultSet.getInt("id"), resultSet.getString("name"), resultSet.getInt("age"));
    }
}
View Code

(3).Service接口

Springboot使用jdbc以及事务支持Springboot使用jdbc以及事务支持
package com.example.demo.jdbc_tx.mapper;


import com.example.demo.jdbc_tx.domain.User;
import org.springframework.jdbc.core.RowMapper;

import java.sql.ResultSet;
import java.sql.SQLException;

public class UserMapper implements RowMapper {
    @Override
    public Object mapRow(ResultSet resultSet, int i) throws SQLException {
        return new User(resultSet.getInt("id"), resultSet.getString("name"), resultSet.getInt("age"));
    }
}
View Code

(4).Service实现

Springboot使用jdbc以及事务支持Springboot使用jdbc以及事务支持
package com.example.demo.jdbc_tx.service.impl;

import com.example.demo.jdbc_tx.domain.User;
import com.example.demo.jdbc_tx.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Service;

@Service
public class UserServiceImp implements UserService {
    private final JdbcTemplate jdbcTemplate;

    @Autowired
    public UserServiceImp(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }

    @Override
    public void save(User user) {
        jdbcTemplate.update("insert into user(name, age) values (?, ?)", user.getName(), user.getAge());
        throw new RuntimeException("事务异常,回滚!");
    }
}
View Code

 (5).Controller测试

Springboot使用jdbc以及事务支持Springboot使用jdbc以及事务支持
package com.example.demo.jdbc_tx.controller;

import com.example.demo.jdbc_tx.domain.User;
import com.example.demo.jdbc_tx.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("user")
public class UserController {
    private final UserService userService;

    @Autowired
    public UserController(UserService userService) {
        this.userService = userService;
    }

    @GetMapping("save")
    public void save(User user) {
        userService.save(user);
    }
}
View Code