Spring jdbctemplate执行插入语句获取id的方法

spring java 文章 2023-03-06 19:47 939 0 全屏看文

AI助手支持GPT4.0

您可以使用以下方法来获取插入数据的id: 

1. 使用JdbcTemplate的update方法,并将KeyHolder对象作为第二个参数传递,如下所示:

public int addPerson(Person person) {
   String sql = "INSERT INTO person(name, age) VALUES (?, ?)";
   KeyHolder keyHolder = new GeneratedKeyHolder();
   jdbcTemplate.update(connection -> {
       PreparedStatement ps = connection
               .prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
       ps.setString(1, person.getName());
       ps.setInt(2, person.getAge());
       return ps;
   }, keyHolder);
   return keyHolder.getKey().intValue();
}

2. 使用SimpleJdbcInsert类并调用executeAndReturnKey方法来将数据插入到表中,并返回自动生成的id,如下所示:

public int addPerson(Person person) {
    SimpleJdbcInsert jdbcInsert = new SimpleJdbcInsert(jdbcTemplate)
            .withTableName("person")
            .usingGeneratedKeyColumns("id");
    Map<String, Object> parameters = new HashMap<>();
    parameters.put("name", person.getName());
    parameters.put("age", person.getAge());
    Number key = jdbcInsert.executeAndReturnKey(new MapSqlParameterSource(parameters));
    return key.intValue();
}


-EOF-

AI助手支持GPT4.0


国内超级便宜服务器

摸鱼人热门新闻聚合

钻级赞助商 我要加入

开发者在线工具

第三方支付技术请加QQ群

相关文章
Spring中使用jdbcTemplate.queryForRowSet取值,日期丢失时分秒的解决方案
SpringBoot最简多线程配置教程
Spring里自带的数组集合用逗号拼接成字符串的方法
Java返回指定索引的泛型参数
定义一个切面日志
随便看看
企业微信通讯录账号被管理员误/恶意删除,怎么办? 9568
问题? 9048
如何快速搭建抽奖助手小程序(无需代码知识) 6177
许涛 大哥在吗, 要解冻小程序的时候提示信息主体不一致, 能帮忙看下吗? 7472
小程序搜一搜全称搜索不显示 麻烦解决一下!谢谢 6793
我的小程序广告收款主体是个体工商户,每个月邮寄两次发票很是麻烦,我年底的时候打包邮寄一次可以么? 6127
如何解决渲染层网络错误Failed to load media? 17393
小程序找号找回 释放昵称? 3252
我的小程序广告主收入5301,实际进账4406,是怎么回事呀? 3108
删除部分微信用户个人数据的通知,怎么删除? 6380