spring NamedParameterJdbcTemplate批量操作sql怎么实现 80
数据库有张表createtabletable_test(namevarchar(50)primarykey,ageint)初始的时候就有两条数据aaa20bbb20现在有...
数据库有张表
create table table_test(name varchar(50) primary key, age int)
初始的时候就有两条数据
aaa 20
bbb 20
现在有几条sql,要用NamedParameterJdbcTemplate批量操作,方法为public boolean myBatchUpdate(String[] sqls)
insert into bdds.table_test values('ccc', 33)
insert into bdds.table_test values('ddd', 44)
update table_test set age=29 where name='aaa'
2. 有几条sql,也要用NamedParameterJdbcTemplate批量操作,方法为public boolean myBatchUpdate(String[] sqls),要求吧所有的sql封装为一个原子事件
insert into bdds.table_test values('fff', 55)
insert into bdds.table_test values('ccc', 33) //主键冲突,那么执行方法myBatchUpdate后'fff', 55不应该插入数据库
myBatchUpdate(String[] sqls)怎么实现? 展开
create table table_test(name varchar(50) primary key, age int)
初始的时候就有两条数据
aaa 20
bbb 20
现在有几条sql,要用NamedParameterJdbcTemplate批量操作,方法为public boolean myBatchUpdate(String[] sqls)
insert into bdds.table_test values('ccc', 33)
insert into bdds.table_test values('ddd', 44)
update table_test set age=29 where name='aaa'
2. 有几条sql,也要用NamedParameterJdbcTemplate批量操作,方法为public boolean myBatchUpdate(String[] sqls),要求吧所有的sql封装为一个原子事件
insert into bdds.table_test values('fff', 55)
insert into bdds.table_test values('ccc', 33) //主键冲突,那么执行方法myBatchUpdate后'fff', 55不应该插入数据库
myBatchUpdate(String[] sqls)怎么实现? 展开
- 你的回答被采纳后将获得:
- 系统奖励15(财富值+成长值)+难题奖励10(财富值+成长值)+提问者悬赏80(财富值+成长值)
1个回答
展开全部
@Test
public void testBatchUpdate() {
NamedParameterJdbcTemplate namedParameterJdbcTemplate = new NamedParameterJdbcTemplate(jdbcTemplate);
String insertSql = "insert into bdds.table_test(name) values(:myName)";
UserModel model = new UserModel();
model.setMyName("name5");
SqlParameterSource[] params = SqlParameterSourceUtils.createBatch(new Object[] {
model, model});
namedParameterJdbcTemplate.batchUpdate(insertSql, params);
Assert.assertEquals(2, jdbcTemplate.queryForInt("select count(*) from test"));
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询