Spring Boot——整合JDBC

868 阅读3分钟

1、SpringData

Spring Data是一个用于简化数据库访问,并支持云服务的开源框架。其主要目标是使得对数据的访问变得方便快捷。

对于数据访问层(DAO),无论是 SQL(关系型数据库) 还是 NOSQL(非关系型数据库),Spring Boot 底层都是采用 Spring Data 的方式进行统一处理。

Sping Data 官网

Sping Data官方文档

maven依赖:

<dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

2、整合JDBC

1、新建一个springboot项目,引入Web、JDBC和Mysql Driver模块

2、相应的启动器为:

       <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</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>

3、编写application.yml配置文件连接数据库

spring:
  datasource:
    username: root
    password: 19990802
    url: jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT
    driver-class-name: com.mysql.jdbc.Driver
   #这个type可以指定数据源类型
   #type: 

4、测试类测试

    //数据源自动装配
    @Autowired
    DataSource dataSource;
    @Test
    void contextLoads() {
        //查看默认的数据源
        System.out.println(dataSource.getClass());//class com.zaxxer.hikari.HikariDataSource

        //有了数据源,就可以获得数据库连接
        try {
            Connection connection = dataSource.getConnection();
            //查看连接
            System.out.println(connection);//HikariProxyConnection@2028767654 wrapping com.mysql.cj.jdbc.ConnectionImpl@3596b249
            //关闭连接
            connection.close();

        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

有了数据库连接,显然就可以 CRUD 操作数据库了。但是我们需要先了解一个对象 JdbcTemplate

JDBCTemplate

  • 有了数据源(com.zaxxer.hikari.HikariDataSource),然后可以拿到数据库连接(java.sql.Connection),有了连接,就可以使用原生的 JDBC 语句来操作数据库;

  • 即使不使用第三方第数据库操作框架,如 MyBatis等,Spring 本身也对原生的JDBC 做了轻量级的封装,即JdbcTemplate。

  • 数据库操作的所有 CRUD 方法都在 JdbcTemplate 中。

  • Spring Boot 不仅提供了默认的数据源,同时默认已经配置好了 JdbcTemplate 放在了容器中,程序员只需自己注入即可使用

  • JdbcTemplate 的自动配置是依赖 org.springframework.boot.autoconfigure.jdbc 包下的 JdbcTemplateConfiguration 类

JdbcTemplate主要提供以下几类方法:

  • execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;
  • update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;
  • query方法及queryForXXX方法:用于执行查询相关语句;
  • call方法:用于执行存储过程、函数相关语句。

测试SpringBoot封装JDBC

package com.cheng.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;
import java.util.Map;

@RestController
public class JDBCController {

    @Autowired
    JdbcTemplate jdbcTemplate;

    //查询全部信息
    @GetMapping("/queryUser")
    //这里没有写实体类,用Map来封装数据
    public List<Map<String,Object>> useList(){
        String sql = "select * from user";
        List<Map<String, Object>> mapList = jdbcTemplate.queryForList(sql);
        return mapList;
    }
    //新增用户信息
    @GetMapping("/addUser")
    public String addUser(){
        String sql = "insert into user (id,name,pwd) values(3,'万里','123456')";
        jdbcTemplate.execute(sql);
        return "添加成功";
    }
    //删除用户信息
    @GetMapping("/deleteUser")
    public String deleteUser(){
        String sql = "delete from user where id=4";
        jdbcTemplate.execute(sql);
        return "删除成功";
    }
    //修改用户信息
    @GetMapping("/updateUser/{id}")//在访问路径后面加上id来修改信息
    public String updateUser(@PathVariable("id") int id){
        String sql = "update  user set name=?,pwd=? where id="+id;
        Object[] objects = new Object[2];
        objects[0] = "小明";
        objects[1] = "123456";
        jdbcTemplate.update(sql,objects);
        return "修改成功";
    }

}