SpringBoot使用JdbcTemplate访问操作数据库基本用法

 更新时间:2022年02月22日 11:44:37   作者:入门小站  
这篇文章主要介绍了SpringBoot使用JdbcTemplate访问操作数据库基本用法,Spring对数据库的操作在jdbc上s面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到JdbcTemplate之中。下文详细内容需要的小伙伴可以参考一下

Spring对数据库的操作在jdbc上s面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到JdbcTemplate之中。

JdbcTemplateSpring-jdbc包下面,还需要Spring-tx包支持,里面包含事务和异常控制.

一、建一个rumenz_springboot库

创建user表:

create table user(
  id int primary key auto_increment,
  name varchar(100) not null default '',
  domain varchar(100) not null default ''
)engine=innodb default charset=utf8;

二、加入pom的依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>

三、SpringBoot配置文件

application.properties

spring.datasource.url=jdbc:mysql://localhost:3306/rumenz_springboot
spring.datasource.username=root
spring.datasource.password=root1234
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

四、创建User实体类

@Builder
@Data
@AllArgsConstructor
public class User  implements RowMapper {
    private Integer id;
    private String name;
    private String domain;

    @Override
    public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
        User user=new User();
        user.setId(rs.getInt("id"));
        user.setName(rs.getString("name"));
        user.setDomain(rs.getString("domain"));
        return user;
    }
}

五、Service接口

UserService.java

package com.rumenz.lession14.controller.service;

import com.rumenz.lession14.controller.entity.User;

import java.util.List;

/**
 * @className: UserService
 * @description: TODO 类描述
 * @author: 入门小站 rumenz.com
 * @date: 2021/12/13
 **/
public interface UserService {
    Integer save(User user);
    List<User> list();
    Integer update(User user);

    Integer batchSave();
}

六、Service接口实现类

UserServiceImpl.java

package com.rumenz.lession14.controller.service.Impl;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.json.JsonMapper;
import com.rumenz.lession14.controller.entity.User;
import com.rumenz.lession14.controller.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Service;

import java.util.ArrayList;
import java.util.List;

/**
 * @className: UserServiceImpl
 * @description: TODO 类描述
 * @author: 入门小站 rumenz.com
 * @date: 2021/12/13
 **/

@Service
public class UserServiceImpl implements UserService {
    @Autowired
    private JdbcTemplate jdbcTemplate;

    @Override
    public Integer save(User user) {
        int reint = jdbcTemplate.update("insert into user(name,domain) values (?,?)", user.getName(), user.getDomain());
        return reint;
    }

    @Override
    public Integer batchSave() {
        String sql="insert into user(name,domain) values(?,?)";
        List<Object[]> par=new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            String[] s=new String[2];
            s[0]="入门小站"+i;
            s[1]="https://rumenz.com/"+i;
            par.add(s);
        }
        int[] ints = jdbcTemplate.batchUpdate(sql, par);
        System.out.println(ints.toString());
        return 0;
    }

    @Override
    public List<User> list() {
        //User实现RowMapper接口,实现接口里的mapRow方法。
        List<User> list = jdbcTemplate.query("select * from user",new User());
        return list;
    }

    @Override
    public Integer update(User user) {
        Integer reint=jdbcTemplate.update("update user set name=?,domain=? where id=?", user.getName(),user.getDomain(),user.getId());
        //
        return reint;
    }


}

七、Controller测试

RumenzController.java

package com.rumenz.lession14.controller;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.rumenz.lession14.controller.entity.User;
import com.rumenz.lession14.controller.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;

import java.util.List;

/**
 * @className: RumenzController
 * @description: TODO 类描述
 * @author: 入门小站 rumenz.com
 * @date: 2021/12/13
 **/
@RestController
@RequestMapping("/rumenz")
public class RumenzController {


    @Autowired
    private UserService userService;


    //添加数据
    @GetMapping("/save")
    public String save(){
        User user=User.builder().name("入门小站").domain("https://rumenz.com").build();
        Integer reint = userService.save(user);
        return reint.toString();
    }

    //批量添加数据
    @GetMapping("/batchSave")
    public String batchSave(){
        Integer reint = userService.batchSave();
        return reint.toString();
    }

    //查询数据
    @GetMapping("/list")
    public String list() throws JsonProcessingException {
        List<User> list = userService.list();
        ObjectMapper objectMapper=new ObjectMapper();
        String val = objectMapper.writeValueAsString(list);
        return val;
    }
    //更新数据
    @GetMapping("/update")
    public String update() throws JsonProcessingException {
        User user=User.builder().id(1).name("入门小站-修改").domain("https://tooltt.com").build();
        Integer reint = userService.update(user);
        return reint.toString();
    }

}

八、总结

常用CURD操作大致使用以下三个方法:

  • 1.execute方法,用于直接执行SQL语句
  • 2.update方法,用户新增修改删除操作
  • 3.query方法,用于查询方法

到此这篇关于SpringBoot使用JdbcTemplate访问操作数据库基本用法的文章就介绍到这了,更多相关SpringBoot使用JdbcTemplate访问操作数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 聊聊如何打印GC日志排查的问题

    聊聊如何打印GC日志排查的问题

    这篇文章主要介绍了聊聊如何打印GC日志排查的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • 基于Java class对象说明、Java 静态变量声明和赋值说明(详解)

    基于Java class对象说明、Java 静态变量声明和赋值说明(详解)

    下面小编就为大家带来一篇基于Java class对象说明、Java 静态变量声明和赋值说明(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 如何解决Project SDK is not defined问题

    如何解决Project SDK is not defined问题

    这篇文章主要介绍了如何解决Project SDK is not defined问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Spring Boot容器加载时执行特定操作(推荐)

    Spring Boot容器加载时执行特定操作(推荐)

    这篇文章主要介绍了Spring Boot容器加载时执行特定操作及spring内置的事件,需要的朋友可以参考下
    2018-01-01
  • Java中SimpleDateFormat 格式化日期的使用

    Java中SimpleDateFormat 格式化日期的使用

    本文主要介绍了Java中SimpleDateFormat 格式化日期的使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • 详解java中面向对象设计模式类与类的关系

    详解java中面向对象设计模式类与类的关系

    这篇文章主要介绍了java面向对象设计模式中类与类之间的关系,下面小编和大家一起来学习一下吧
    2019-05-05
  • java枚举类型-Enum

    java枚举类型-Enum

    本文详细介绍了 Java1.5 引入的新特性枚举中的关键字enum,运用大量的代码加以解释,相信可以帮助到正在学习该知识的小伙伴,大家可以参考一下
    2021-08-08
  • java图形化界面实现简单混合运算计算器的示例代码

    java图形化界面实现简单混合运算计算器的示例代码

    这篇文章主要介绍了java图形化界面实现简单混合运算计算器的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • mybatisplus解除分页限制的实现

    mybatisplus解除分页限制的实现

    这篇文章主要介绍了mybatisplus解除分页限制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Java实现把文件压缩成zip文件的示例代码

    Java实现把文件压缩成zip文件的示例代码

    这篇文章主要为大家介绍了如何通过Java语言实现将文件压缩成zip文件,本文中示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02

最新评论