三种使用Spring JdbcTemplate实现update或insert操作
第一种方式,重载PreparedStatementCreator
jdbcTemplate.update(new PreparedStatementCreator(){
public PreparedStatement createPreparedStatement(Connection conn){
String sql="insert into user (name,age) values(?,?)";
PreparedStatement ps=con.prepareStatement(sql);
ps.setString(1,name);
ps.setInt(2,age);
return ps;
}
}
);
第二种方式,重载PreparedStatementSetter
jdbcTemplate.update("insert into user(name,age) values(?,?)",new PreparedStatementSetter(){
public void setValues(PreparedStatement ps) throws SQLException {
ps.setString(1,name);
ps.setInt(2,age);
}
});
//jdbcTemplate会自动创建PreparedStatementCreator实例,以提供传递给setValues方法的ps对象
第三种方式,直接使用SQL
jdbcTemplate.update("insert into user (name,age) "+"values (' " + name + " ', " +age +")");
//批量更新
public void insertBooks(List<Book> book)
{
final List<Book> tempBook=book;
String sql="insert into book(name,pbYear) values(?,?)";
jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter()
{
public void setValues(PreparedStatement ps,int i)throws SQLException
{
String name=tempBook.get(i).getName();
int pbYear=tempBook.get(i).getPbYear();
ps.setString(1, name);
ps.setInt(2, pbYear);
}
public int getBatchSize()
{
return 25;
}
});
}
分享到:
相关推荐
`JdbcTemplate`的`batchUpdate`方法就是用来实现这样的功能,它可以批量执行更新语句,如INSERT、UPDATE或DELETE。 `batchUpdate`方法的基本使用如下: ```java int[] result = jdbcTemplate.batchUpdate( ...
**基于注解的Spring JdbcTemplate** 在Java世界中,Spring框架是企业级应用开发的首选。Spring JDBC模絫提供了一种简洁的方式来处理数据库操作,而`Spring JdbcTemplate`是这个模絫的核心组件。本教程将深入探讨...
1. **JdbcTemplate对象**:这是Spring JdbcTemplate的核心,它包含了执行SQL语句的所有方法,如update()用于更新,query()用于查询,insert()用于插入等。 2. **参数绑定**:JdbcTemplate支持多种方式的参数绑定,...
本文将深入探讨如何利用Spring JdbcTemplate进行CURD(Create、Read、Update、Delete)操作。 1. 创建(Create) 创建数据通常涉及插入新的记录到数据库表中。JdbcTemplate提供了`update()`方法来执行SQL的INSERT...
**Spring JdbcTemplate**是Spring框架中的一个核心组件,主要用于简化Java数据库访问。它提供了一种模板化的方式来执行SQL语句,使得开发人员可以避免编写大量的重复代码,专注于业务逻辑,而不是底层的数据库交互...
4. `spring-tx-5.0.0.RELEASE.jar`:提供了事务管理功能,可以配合JDBCTemplate进行事务的声明式或编程式管理。 5. `commons-logging-1.2.jar`:Apache Commons Logging库,是Spring的日志适配器,允许我们灵活地...
Spring的JdbcTemplate是Spring框架中用于简化数据库操作的工具类,它是基于JDBC但又抽象出了一层,避免了直接与数据库驱动API交互,从而提高了代码的可读性和可维护性。本文将深入探讨Spring JdbcTemplate的常用方法...
Spring JdbcTemplate是Spring框架中的一个核心组件,主要用来简化数据库操作。它提供了一种模板方法设计模式,将SQL语句的执行与结果处理进行了抽象,使得开发者可以更加专注于业务逻辑,而无需关心底层数据访问的...
int count = jdbcTemplate.update("INSERT INTO account (name, money) VALUES (?, ?)", "Tom", 500); ``` ##### 更新操作 ```java int count = jdbcTemplate.update("UPDATE account SET money = ? WHERE id = ?...
Spring的JdbcTemplate是Spring框架中的一个核心组件,用于简化数据库操作。它提供了一种模板方法模式,抽象出了一些常见的数据库访问任务,使得开发者无需关注低级的JDBC细节,如打开和关闭连接、处理结果集等,从而...
在本文中,我们将深入探讨Spring框架中的一个核心组件——JdbcTemplate。JdbcTemplate是Spring提供的一种数据库操作工具,它简化了数据库访问,使开发者...在实际项目中,JdbcTemplate是Spring开发中不可或缺的一部分。
jdbcTemplate.update("INSERT INTO users(name, email) VALUES (?, ?)", "Alice", "alice@example.com"); ``` 2. **更新数据**: ```java jdbcTemplate.update("UPDATE users SET email = ? WHERE id = ?", "new...
这个系统可能包括了图书的增删改查等功能,通过Spring JdbcTemplate实现。例如,我们可以创建一个`BookService`类,该类注入了JdbcTemplate并提供操作图书的方法: ```java @Service public class BookService { @...
3. **结果集处理**:对于查询操作,JdbcTemplate可以将结果集映射到Java对象,这通常通过实现RowMapper接口或使用BeanPropertyRowMapper类来完成。RowMapper允许自定义对象映射逻辑,而BeanPropertyRowMapper则会...
- **事务管理**:Spring 提供的 PlatformTransactionManager 与 JdbcTemplate 结合,可以实现事务的编程式和声明式管理。 - **异常处理**:JdbcTemplate 将数据库异常转换为统一的 DataAccessException,便于错误...
Java Spring JdbcTemplate是Spring框架中一个非常重要的组件,它为开发者提供了一种简单而有效的方式来操作...通过熟练掌握JdbcTemplate的使用,你可以更高效地构建基于Spring的应用程序,实现与数据库的稳定交互。
在Spring中,声明式事务管理是通过在方法或类上使用@Transactional注解来实现的。这种方式使得事务管理变得简单且易于维护。例如,如果我们希望在一个方法中的所有数据库操作都在同一个事务中执行,可以这样做: ``...
nimble-orm的核心在于它能够帮助开发者快速实现对MySQL数据库的增(Insert)、删(Delete)、改(Update)和查(Select)操作,降低了数据库操作的复杂性。 使用nimble-orm有以下几个主要优点: 1. **简单易用**:...
`addOrUpdateOrDelete` 方法则调用了`JdbcTemplate`的`update`方法来执行DML语句(INSERT, UPDATE, DELETE)。如果提供了参数,它创建了一个`PreparedStatementSetter`的匿名子类,遍历参数数组并设置预编译SQL语句...