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

 

 

案例操作

一、创建接口

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

UDS(统一诊断服务)是在车辆中使用的一种通信协议,它是基于ISO 14229标准开发的,用于车辆的诊断通信。在UDS中,数据的传输涉及多种不同类型的,包括连续帧和多等。 连续帧(Flow Control Frame):在处理较大的数据传输时,如果数据量超过了能够承载的大小,就需要将数据分割成多个来传输。连续帧用于标记一个数据消息的多个的连续部分。它们通常会包含一个连续帧计数器,这个计数器会指明当前是该消息中的第几,以及消息总共有多少(Flow Control Frame):用于制数据的发送速率,确保发送端和接收端的数据处理能够匹配。可以是正向的,比如发送方请求继续发送更多的数据,也可以是反向的,比如接收方请求发送方减慢发送速度或者暂停发送。在UDS中,制通常通过发送特定的消息(如ISO 14229-3中定义的和连续帧)来实现。 多(Multi Frame):当传输的数据量超过一个的最大数据载荷时,就需要使用多传输。多传输涉及到将数据分成多个连续的,每个都有序号和总数的信息,接收方通过这些信息将多个重新组合成原始的数据消息。 在使用多传输时,发送方和接收方之间的通信需要有相应的协议来确保数据的完整性和顺序性。如果在数据传输过程中,接收方没有正确地接收到某个,它可以通过发送来请求重传那个特定的
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

托马斯-酷涛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值