七十三、Spring与DAO操作 update()

简介: 七十三、Spring与DAO操作 update()

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 语句中所包含的动态参数。 其返回值为所影响记录的条数。一般不用。


1.png


2.gif




案例操作


一、创建接口


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)

六、程序运行

3.png



七、再次查看数据库



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第一条数据已被修改,已添加最后一条数据


相关文章
|
3月前
|
NoSQL Java Redis
Redis进阶-Jedis以及Spring Boot操作 Redis 5.x Cluster
Redis进阶-Jedis以及Spring Boot操作 Redis 5.x Cluster
82 0
|
2月前
|
Java Spring 容器
spring如何进行依赖注入,通过set方法把Dao注入到serves
spring如何进行依赖注入,通过set方法把Dao注入到serves
|
2月前
|
存储 运维 Java
Spring运维之boot项目开发关键之日志操作以及用文件记录日志
Spring运维之boot项目开发关键之日志操作以及用文件记录日志
38 2
|
2月前
|
Java 数据库连接 数据库
Spring日志完结篇,MyBatis操作数据库(入门)
Spring日志完结篇,MyBatis操作数据库(入门)
|
2月前
|
Java Spring
spring练习32-删除用户操作
spring练习32-删除用户操作
|
3月前
|
NoSQL Java 网络安全
在spring中操作Redis
在spring中操作Redis
44 0
|
3月前
|
SQL Java 数据库连接
Springboot框架整合Spring JDBC操作数据
JDBC是Java数据库连接API,用于执行SQL并访问多种关系数据库。它包括一系列Java类和接口,用于建立数据库连接、创建数据库操作对象、定义SQL语句、执行操作并处理结果集。直接使用JDBC涉及七个步骤,包括加载驱动、建立连接、创建对象、定义SQL、执行操作、处理结果和关闭资源。Spring Boot的`spring-boot-starter-jdbc`简化了这些步骤,提供了一个在Spring生态中更便捷使用JDBC的封装。集成Spring JDBC需要添加相关依赖,配置数据库连接信息,并通过JdbcTemplate进行数据库操作,如插入、更新、删除和查询。
40 0
|
3月前
|
SQL Java 数据库连接
Springboot框架整合Spring Data JPA操作数据
Spring Data JPA是Spring基于ORM和JPA规范封装的框架,简化了数据库操作,提供增删改查等接口,并可通过方法名自动生成查询。集成到Spring Boot需添加相关依赖并配置数据库连接和JPA设置。基础用法包括定义实体类和Repository接口,通过Repository接口可直接进行数据操作。此外,JPA支持关键字查询,如通过`findByAuthor`自动转换为SQL的`WHERE author=?`查询。
45 0
|
3月前
|
JSON Java 数据处理
Spring Boot与Jsonson对象:灵活的JSON操作实战
【4月更文挑战第28天】在现代Web应用开发中,JSON数据格式的处理至关重要。假设 "Jsonson" 代表一个类似于Jackson的库,这样的工具在Spring Boot中用于处理JSON。本篇博客将介绍Spring Boot中处理JSON数据的基本概念,并通过实际例子展示如何使用类似Jackson的工具进行数据处理。
126 0
|
3月前
ssm(Spring+Spring mvc+mybatis)Dao层实现类——DeptDaoImpl
ssm(Spring+Spring mvc+mybatis)Dao层实现类——DeptDaoImpl