> 文章列表 > spring5(六):JdbcTemplate

spring5(六):JdbcTemplate

spring5(六):JdbcTemplate

spring5(六):JdbcTemplate

  • 前言
  • 一、 JdbcTemplate概述
  • 二、准备工作
  • 三、JdbcTemplate 操作数据库(添加)
  • 四、JdbcTemplate 操作数据库(修改和删除)
  • 五、JdbcTemplate 操作数据库(查询返回某个值)
  • 六、JdbcTemplate 操作数据库(查询返回对象)
  • 七、JdbcTemplate 操作数据库(查询返回集合)
  • 八、JdbcTemplate 操作数据库(批量操作)
    • 1、JdbcTemplate 实现批量修改操作
    • 2、JdbcTemplate 实现批量删除操作


前言

本博主将用CSDN记录软件开发求学之路上亲身所得与所学的心得与知识,有兴趣的小伙伴可以关注博主!也许一个人独行,可以走的很快,但是一群人结伴而行,才能走的更远!

一、 JdbcTemplate概述

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

二、准备工作

① 引入相关 jar

spring5(六):JdbcTemplate

② 在 spring 配置文件配置数据库连接池

  <!-- 数据库连接池 --><bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"destroy-method="close"><property name="url" value="jdbc:mysql:///user_db" /><property name="username" value="root" /><property name="password" value="root" /><property name="driverClassName" value="com.mysql.jdbc.Driver" /></bean>

③ 配置 JdbcTemplate 对象,注入 DataSource

<!-- JdbcTemplate对象 --><bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"><!--注入dataSource--><property name="dataSource" ref="dataSource"></property></bean>

④ 创建 service 类,创建 dao 类,在 dao 注入 jdbcTemplate 对象

BookDao类

public interface BookDao {public void add();
}

BookDaoImpl类

@Repository
public class BookDaoImpl implements  BookDao{@Autowiredprivate JdbcTemplate jdbcTemplate;@Overridepublic void add() {}
}

Bookservice类

@Service
public class BookService {@Autowiredprivate BookDao bookDao;
}
<context:component-scan base-package="dao,service"></context:component-scan>

三、JdbcTemplate 操作数据库(添加)

① 对应数据库创建实体类

public class Book {private String bookId;private String bookname;private String bstatus;@Overridepublic String toString() {return "Book{" +"bookId='" + bookId + '\\'' +", bookname='" + bookname + '\\'' +", bstatus='" + bstatus + '\\'' +'}';}public String getBookId() {return bookId;}public void setBookId(String bookId) {this.bookId = bookId;}public String getBookname() {return bookname;}public void setBookname(String bookname) {this.bookname = bookname;}public String getBstatus() {return bstatus;}public void setBstatus(String bstatus) {this.bstatus = bstatus;}@Overridepublic boolean equals(Object o) {if (this == o) return true;if (o == null || getClass() != o.getClass()) return false;Book book = (Book) o;return Objects.equals(bookId, book.bookId) &&Objects.equals(bookname, book.bookname) &&Objects.equals(bstatus, book.bstatus);}@Overridepublic int hashCode() {return Objects.hash(bookId, bookname, bstatus);}
}

② 编写 service 和 dao

(1)在 dao 进行数据库添加操作

(2)调用 JdbcTemplate 对象里面 update 方法实现添加操作

@Repository
public class BookDaoImpl implements  BookDao{@Autowiredprivate JdbcTemplate jdbcTemplate;@Overridepublic int add(Book book) {String sql="insert t_book values(?,?,?)";int update = jdbcTemplate.update(sql,book.getBookId(),book.getBookname(),book.getBstatus());return update;}}

测试:

public class TestBook {@Testpublic void testAdd(){ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml");BookService bookservice = context.getBean("bookService", BookService.class);Book book  = new Book("01","java","0");bookservice.add(book);}
}

四、JdbcTemplate 操作数据库(修改和删除)

1、修改

@Override
public void updateBook(Book book) {String sql = "update t_book set username=?,ustatus=? where user_id=?";Object[] args = {book.getUsername(), book.getUstatus(),book.getUserId()};int update = jdbcTemplate.update(sql, args);System.out.println(update);
}

2、删除

@Override
public void delete(String id) {String sql = "delete from t_book where user_id=?";int update = jdbcTemplate.update(sql, id);System.out.println(update);

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

⭕ 查询表里面有多少条记录,返回是某个值
⭕ 使用 JdbcTemplate 实现查询返回某个值代码

spring5(六):JdbcTemplate

有两个参数

  1. 第一个参数:sql 语句
  2. 第二个参数:返回类型 Class

代码演示:

@Override
public int selectCount() {String sql = "select count(*) from t_book";Integer count = jdbcTemplate.queryForObject(sql, Integer.class);return count;
}

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

⭕ 场景:查询图书列表分页…

⭕ 调用 JdbcTemplate 方法实现查询返回对象

spring5(六):JdbcTemplate

⭕ 有三个参数

  1. 第一个参数:sql 语句
  2. 第二个参数:RowMapper 是接口,针对返回不同类型数据,使用这个接口里面实现类完成数据封装
  3. 第三个参数:sql 语句值
//查询返回对象
@Override
public Book findBookInfo(String id) {String sql = "select * from t_book where user_id=?";//调用方法Book book = jdbcTemplate.queryForObject(sql, new 
BeanPropertyRowMapper<Book>(Book.class), id);return book;
}

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

⭕ 场景:查询图书列表分页…

⭕ 调用 JdbcTemplate 方法实现查询返回集合

⭕ 有三个参数

  1. 第一个参数:sql 语句
  2. 第二个参数:RowMapper 是接口,针对返回不同类型数据,使用这个接口里面实现类完成数据封装
  3. 第三个参数:sql 语句值
//查询返回集合
@Override
public List<Book> findAllBook() {String sql = "select * from t_book";//调用方法List<Book> bookList = jdbcTemplate.query(sql, new 
BeanPropertyRowMapper<Book>(Book.class));return bookList;
}

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

⭕ 批量操作:操作表里面多条记录

⭕ JdbcTemplate 实现批量添加操作

spring5(六):JdbcTemplate

⭕ 有两个参数

  1. 第一个参数:sql 语句
  2. 第二个参数:List 集合,添加多条记录数据
//批量添加
@Override
public void batchAddBook(List<Object[]> batchArgs) {String sql = "insert into t_book values(?,?,?)";int[] ints = jdbcTemplate.batchUpdate(sql, batchArgs);System.out.println(Arrays.toString(ints));
}
//批量添加测试
List<Object[]> batchArgs = new ArrayList<>();
Object[] o1 = {"3","java","a"};
Object[] o2 = {"4","c++","b"};
Object[] o3 = {"5","MySQL","c"};
batchArgs.add(o1);
batchArgs.add(o2);
batchArgs.add(o3);
//调用批量添加
bookService.batchAdd(batchArgs);

1、JdbcTemplate 实现批量修改操作

//批量修改
@Override
public void batchUpdateBook(List<Object[]> batchArgs) {String sql = "update t_book set username=?,ustatus=? where user_id=?";int[] ints = jdbcTemplate.batchUpdate(sql, batchArgs);System.out.println(Arrays.toString(ints));
}
//批量修改
List<Object[]> batchArgs = new ArrayList<>();
Object[] o1 = {"java0909","a3","3"};
Object[] o2 = {"c++1010","b4","4"};
Object[] o3 = {"MySQL1111","c5","5"};
batchArgs.add(o1);
batchArgs.add(o2);
batchArgs.add(o3);
//调用方法实现批量修改
bookService.batchUpdate(batchArgs);

2、JdbcTemplate 实现批量删除操作

//批量删除
@Override
public void batchDeleteBook(List<Object[]> batchArgs) {String sql = "delete from t_book where user_id=?";int[] ints = jdbcTemplate.batchUpdate(sql, batchArgs);System.out.println(Arrays.toString(ints));
}
//批量删除
List<Object[]> batchArgs = new ArrayList<>();
Object[] o1 = {"3"};
Object[] o2 = {"4"};
batchArgs.add(o1);
batchArgs.add(o2);
//调用方法实现批量删除
bookService.batchDelete(batchArgs);