Spring学习 —— JdbcTemplate操作数据库

JdbcTemplate(概念和准备)

1、概念

(1)Spring框架对JDBC进行封装,使用JDBCTemplate方便实现对数据库操作

2、准备工作

(1)引入相关jar包
在这里插入图片描述
(2)在Spring配置文件配置数据库连接池
在这里插入图片描述
(3)配置JdbcTemplate对象,注入DataSource
在这里插入图片描述
(4)创建service类,dao类,在dao注入jdbcTemplate对象
①组件扫描
②Service
在这里插入图片描述
③Dao
在这里插入图片描述

JdbcTemplate操作数据库(添加、修改和删除)添加为例

1、对应数据库表创建实体类
2、编写service和dao

(1)在dao和service增加添加、修改和删除方法
在这里插入图片描述
(2)调用JdbcTemplate对象里面update方法实现添加、修改和删除方法
在这里插入图片描述
第一个参数:sql语句
第二个参数:可变参数,设置sql语句值
(3)测试类(实际情况下book的值是通过页面传输过来的)
在这里插入图片描述

JdbcTemplate操作数据库(查询返回某个值)

1、查询表里有多少条记录 select count(*) from t_book
2、使用JdbcTemplate实现查询返回某个值的代码

在这里插入图片描述
第二个参数 返回类型的Class
实现BookService类方法
在这里插入图片描述
实现BookDao类方法
在这里插入图片描述

JdbcTemplate操作数据库(查询返回对象)

1、场景:查询某本书图书详情
2、调用JdbcTemplate方法实现查询返回对象

在这里插入图片描述
第二个参数:RowMappe接口,返回不同类型数据,使用这个接口里面实现类完成数据封装
第三个参数:sql语句值
在这里插入图片描述

JdbcTemplate操作数据库(查询返回集合)

1、场景:查询图书列表分页
2、调用JdbcTemplate方法实现查询返回对象

在这里插入图片描述
在这里插入图片描述

JdbcTemplate操作数据库(批量操作)

1、操作表里多条记录
2、批量添加

在这里插入图片描述
第二个参数:List集合,添加多条记录的数据
在这里插入图片描述

3、批量删除

在这里插入图片描述

4、批量修改

在这里插入图片描述

代码目录

代码目录

BookDao代码

package jdbcTemplate.dao;

import jdbcTemplate.entity.Book;
import org.springframework.stereotype.Service;

import java.util.List;

public interface BookDao {
   

    void add(Book book);

    void update(Book book);

    void delete(String id);

    int selectCount();

    Book findBookInfo(String id);

    List<Book> findAllBook();

    void batchAddBook(List<Object[]> batchArgs);

    void batchUpdateBook(List<Object[]> batchArgs);

    void batchDeleteBook(List<Object[]> batchArgs);
}

BookDaoImpl代码

package jdbcTemplate.dao;

import jdbcTemplate.entity.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.Arrays;
import java.util.List;

@Repository
public class BookDaoImpl implements BookDao{
   
    @Autowired
    private JdbcTemplate jdbcTemplate;

    @Override
    public void add(Book book) {
   
        String sql = "insert into t_book values(?,?,?)";
        jdbcTemplate.update(sql,book.getUserId(),book.getUsername(),book.getUstatus());
        
    }

    @Override
    public void update(Book book) {
   
        String sql = "update t_book set username=?,ustatus=? where user_id=?";
        jdbcTemplate.update(sql,book.getUsername(),book.getUstatus(),book.getUserId());

    }

    @Override
    public void delete(String id) {
   
        String sql = "delete from t_book where user_id=?";
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring JdbcTemplateSpring框架提供的一个对JDBC进行封装的工具类,它可以简化JDBC编程的复杂性,提供了一种更简便的方式来访问数据库JdbcTemplate的原理是将JDBC的访问进行封装,提供了一些常用的操作方法,例如查询、更新、批量操作等。它通过DataSource来获取JDBC的连接,并通过Connection对象进行JDBC的操作,最后释放连接资源。 使用JdbcTemplate进行数据库操作的步骤如下: 1. 配置数据源,配置JdbcTemplate。 2. 在代码中通过JdbcTemplate对象进行数据库操作。 下面是一个简单的例子: 配置数据源和JdbcTemplate: ```xml <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/test"/> <property name="username" value="root"/> <property name="password" value="root"/> </bean> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="dataSource"/> </bean> ``` 在代码中通过JdbcTemplate对象进行数据库操作: ```java @Autowired private JdbcTemplate jdbcTemplate; public void insertUser(User user) { String sql = "INSERT INTO user(name, age) VALUES(?, ?)"; jdbcTemplate.update(sql, user.getName(), user.getAge()); } public List<User> getUsers() { String sql = "SELECT * FROM user"; List<User> users = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class)); return users; } ``` 在上面的代码中,我们通过@Autowired注解注入了JdbcTemplate对象,并使用它来执行插入和查询操作。 通过JdbcTemplate,我们可以使用占位符来传递参数,也可以使用BeanPropertyRowMapper将查询结果映射为Java对象。 总的来说,Spring JdbcTemplate的原理是封装了JDBC的访问,提供了一种更便捷的方式来操作数据库

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值