springBoot整合JdbcTemplate进行数据持久化的基本操作

什么是JdbcTemplate?

JdbcTemplate是Spring的一部分,是对数据库的操作在jdbc的封装,处理了资源的建立和释放(不需要我们管理连接了),我们只需要提供SQL语句(不需要我们设置参数了)和提取结果(查询时候可以直接返回对应的实体类),使JDBC更加易于使用。
JdbcTemplate使用spring的注入功能,把DataSource注册到JdbcTemplate之中。
spring源码地址

为什么需要JdbcTemplate?
使用jdbc时,每次都需要自己获取PreparedStatement,输入sql语句参数,关闭连接等操作。造成操作冗余。影响我们打代码的效率。有了JDBCTemplate以后就可以只写SQL语句就可以了。

JdbcTemplate的基本使用步骤

本教程使用的开发IED为IDEA基于maven

1.pom.xml中引入相关依赖

对于JdbcTemplate的使用,除了基础的spring依赖之外,需要的相关依赖有

1.mysql-connector
2.spring jdbc
3.druid

pom.xml文件如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.7.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.mzc</groupId>
    <artifactId>infotest</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>infotest</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.9</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jdbc</artifactId>
        </dependency>
        <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>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

2.编写配置

application.properties文件如下:

server.port=8081
spring.application.name=travels

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/jdbctest?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
spring.datasource.username=root
spring.datasource.password=277171

数据库有关的信息,例如spring.datasource.url、usename以及password,根据自己的实际情况进行配置

3.编写持久层,这里以Book进行举例

Book.java

package com.mzc.Model;

/**
 * @author jikeMisma
 * @date 2020/6/19 - 10:51
 */
public class Book {

    int id;
    String bookname;
    String author;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getBookname() {
        return bookname;
    }

    public void setBookname(String bookname) {
        this.bookname = bookname;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }
}

4.编写DAO层

BookDao.java

package com.mzc.Dao.impl;

import com.mzc.Model.Book;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;

import java.util.List;

/**
 * @author jikeMisma
 * @date 2020/6/19 - 10:52
 */

@Repository
public class BookDao {


    @Autowired
    JdbcTemplate jdbcTemplate;

    public int addBook(Book book) {

        return jdbcTemplate.update("insert into t_book(bookname,author) values  (?,?)", book.getBookname(), book.getAuthor());
    }

    public int updateBook(Book book) {
        return jdbcTemplate.update("insert into t_book set bookname=?,author=? where id =?", book.getBookname(), book.getAuthor(), book.getId());
    }

    public int deleteBookBtId(Integer id) {
        return jdbcTemplate.update("delete from t_book where id=?", id);
    }


    public Book getBookById(Integer id){
        return  jdbcTemplate.queryForObject("select * from t_book where id=?",new BeanPropertyRowMapper<>(Book.class),id);

    }

    public List<Book> getAllBooks(){
        return jdbcTemplate.query("select * from t_book",new BeanPropertyRowMapper<>(Book.class));
    }


}

5.编写Service层

BookService .java

package com.mzc.Service.impl;

import com.mzc.Dao.impl.BookDao;
import com.mzc.Model.Book;
import lombok.experimental.Accessors;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 * @author jikeMisma
 * @date 2020/6/19 - 11:13
 */

@Service
public class BookService {


    @Autowired
    BookDao bookDao;

    public int addBook(Book book){
        return bookDao.addBook(book);
    }

    public int updateBook(Book book){
        return bookDao.updateBook(book);
    }

    public int deleteBookBtId(Integer id){
        return bookDao.deleteBookBtId(id);
    }

    public Book getBookById(Integer id){
        return bookDao.getBookById(id);
    }

    public List<Book> getAllBooks(){
        return bookDao.getAllBooks();
    }
}

6.创建Controller进行调用
package com.mzc.Controller;

import com.mzc.Model.Book;
import com.mzc.Service.impl.BookService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

/**
 * @author jikeMisma
 * @date 2020/6/19 - 11:16
 */
@Controller
public class BookController {


    @Autowired
    BookService bookService;

    @GetMapping("bookOps")
    public void bookOps(){
        Book b1 = new Book();
        b1.setBookname("Redis设计与实现");
        b1.setAuthor("黄健宏");
        int i = bookService.addBook(b1);
        System.out.println("addBood>>>"+i);

        Book b2 = new Book();
        b2.setBookname("大数据技术原理与应用");
        b2.setAuthor("林子雨");
        int updatebook = bookService.addBook(b2);
        System.out.println("updateBook>>>"+updatebook);

        Book b3 = bookService.getBookById(5);
        System.out.println("getBookByid>>>"+b3);

    }
}

这时候编写的数据就可以写入数据库进行持久化了。

运行截图如下

启动springBoot项目
在这里插入图片描述
在浏览器访问对应的地址
在这里插入图片描述
查看数据库数据是否入库:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/mzc_love/article/details/106856311