七十三、Spring与DAO操作 update()
【摘要】
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,并返回受影响的行数。 |
前景连接
此案例在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)