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

举报
托马斯-酷涛 发表于 2022/05/25 23:05:56 2022/05/25
1.3k+ 0 0
【摘要】 update()方法可以完成插入、更新和删除数据的操作。在JdbcTemplate类中,提供了一系列的update()方法,其常用方法下表所示: 方法说明int update(String sql)该方法是最简单的update方法重载形式,它直接执行传入的SQL语句,并返回受影响的行数。int update(Prepared...

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

文章来源: tuomasi.blog.csdn.net,作者:托马斯-酷涛,版权归原作者所有,如需转载,请联系作者。

原文链接:tuomasi.blog.csdn.net/article/details/123169124

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。