update()方法可以完成插入、更新和删除数据的操作。在JdbcTemplate类中,提供了一系列的update()方法,其常用方法下表所示:
方法 |
说明 |
int update(String sql) |
该方法是最简单的update方法重载形式,它直接执行传入的SQL语句,并返回受影响的行数。 |
int update(PreparedStatementCreatorpsc) |
该方法执行从 PreparedStatementCreator返回的语句,然后返回受影响的行数。 |
int update(String sql, PreparedStatementSetter pss) |
该方法通过PreparedStatementSetter设置SQL语句中的参数,并返回受影响的行数。 |
int update(Stringsql,Object... args) |
该方法使用Object...设置sQL语句中的参数,要求参数不能为NULL,并返回受影响的行数。 |
前景连接
七十二、Spring与DAO操作 execute()_托马斯-酷涛的博客-CSDN博客
Spring 与 Dao 部分,是 Spring 的两大核心技术 IoC 与 AOP 的典型应用体现对于 JDBC 模板的使用,是 IoC 的应用,是将 JDBC 模板对象注入给了 Dao 层的实现类。对于 Spring 的事务管理,是 AOP 的应用,将事务作为切面织入到了 Service 层的业务方 法中。Spring 与 JDBC 模板为了避免直接使用 JDBC 而带来的复杂且冗长的代码,Spring 提供了一个强有力的模板 类---JdbcTe...
https://blog.csdn.net/m0_54925305/article/details/123149019?spm=1001.2014.3001.5501
此案例在execute功能上进行拓展程序功能
对 DB 的增、删、改都是通过 update()方法实现的。该方法常用的重载方法有两个:
public int update ( String sql)
public int update ( String sql, Object… args)
第 1 个参数为要执行的 sql 语句,第 2 个参数为要执行的 sql 语句中所包含的动态参数。 其返回值为所影响记录的条数。一般不用。
案例操作
一、创建接口
import java.util.List; public interface AccountDao { // 添加 public int addAccount(Account account); // 更新 public int updateAccount(Account account); // 删除 public int deleteAccount(int id); }
二、创建实现类
import java.util.List; import org.springframework.jdbc.core.BeanPropertyRowMapper; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.RowMapper; public class AccountDaoImpl implements AccountDao { // 声明JdbcTemplate属性及其setter方法 private JdbcTemplate jdbcTemplate; public void setJdbcTemplate(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } // 添加账户 public int addAccount(Account account) { // 定义SQL String sql = "insert into account(username,balance) value(?,?)"; // 定义数组来存放SQL语句中的参数 Object[] obj = new Object[] { account.getUsername(), account.getBalance() }; // 执行添加操作,返回的是受SQL语句影响的记录条数 int num = this.jdbcTemplate.update(sql, obj); return num; } // 更新账户 public int updateAccount(Account account) { // 定义SQL String sql = "update account set username=?,balance=? where id = ?"; // 定义数组来存放SQL语句中的参数 Object[] params = new Object[] { account.getUsername(), account.getBalance(), account.getId() }; // 执行添加操作,返回的是受SQL语句影响的记录条数 int num = this.jdbcTemplate.update(sql, params); return num; } // 删除账户 public int deleteAccount(int id) { // 定义SQL String sql = "delete from account where id = ? "; // 执行添加操作,返回的是受SQL语句影响的记录条数 int num = this.jdbcTemplate.update(sql, id); return num; } }
三、加入依赖
<!--定义id为accountDao的Bean--> <bean id="accountDao" class="com.Example.jdbc.AccountDaoImpl"> <!-- 将jdbcTemplate注入到accountDao实例中 --> <property name="jdbcTemplate" ref="jdbcTemplate" /> </bean>
四、创建测试类
import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class JdbcTemplateTest_update { public static void main(String[] args) { // 加载配置文件 ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml"); // 获取AccountDao实例 AccountDao accountDao = (AccountDao) applicationContext.getBean("accountDao"); // 创建Account对象,并向Account对象中添加数据 Account account = new Account(); account.setUsername("tom"); account.setBalance(1000.00); // 执行addAccount()方法,并获取返回结果 int num = accountDao.addAccount(account); if (num > 0) { System.out.println("成功插入了" + num + "条数据!"); } else { System.out.println("插入操作执行失败!"); } // 修改数据 Account ud = new Account(); ud.setId(1); ud.setUsername("tom"); ud.setBalance(2000.00); // 执行updata方法并返回结果 int sum = accountDao.updateAccount(ud); if (sum > 0) { System.out.println("成功修改了" + sum + "条数据!"); } else { System.out.println("修改操作执行失败!"); } } //执行findAccountById()方法 }
五、查看数据库
mysql> use spring; Database changed mysql> select * from account; +----+-----------+---------+ | id | username | balance | +----+-----------+---------+ | 1 | 孙悟空 | 100 | | 2 | 唐僧 | 1000 | | 3 | 猪八戒 | 2000 | | 4 | 沙僧 | 5000 | +----+-----------+---------+ 4 rows in set (0.04 sec)
六、程序运行
七、再次查看数据库
mysql> select * from account; +----+-----------+---------+ | id | username | balance | +----+-----------+---------+ | 1 | tom | 2000 | | 2 | 唐僧 | 1000 | | 3 | 猪八戒 | 2000 | | 4 | 沙僧 | 5000 | | 5 | tom | 1000 | +----+-----------+---------+ 5 rows in set (0.00 sec)
数据表中 account第一条数据已被修改,已添加最后一条数据