mybatis如何实现新增save结束后自动返回主键id
发表于:2024-09-21 作者:千家信息网编辑
千家信息网最后更新 2024年09月21日,小编给大家分享一下mybatis如何实现新增save结束后自动返回主键id,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!m
千家信息网最后更新 2024年09月21日mybatis如何实现新增save结束后自动返回主键id
小编给大家分享一下mybatis如何实现新增save结束后自动返回主键id,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
mybatis新增save结束后自动返回主键id
1.使用场景
save操作之前实体类中id为null,save之后自动返回带id的实体类
@Override public ChartPagePanel save(ChartPagePanel entity) { UserDetails user = SecurityContextHolder.getUserDetails(); entity.setCreateUser(user.getUsername()); entity.setLastModifyUser(user.getUsername()); //entity中的id为null chartPagePanelMapper.save(entity); //经过save操作后自动返回带id的entity // savePanelManage(entity); 其中的entity带有id savePanelManage(entity); return entity; } @Transactional public void savePanelManage(ChartPagePanel entity){ if(entity.getChartPageManges()!=null && entity.getChartPageManges().size()>0) { Mapmap = new HashMap<>(); for (int i = 0; i < entity.getChartPageManges().size(); i++) { int manageId = entity.getChartPageManges().get(i).getId(); map.put("manageId", manageId); map.put("panelId", entity.getId()); chartPagePanelManageMapper.save(map); } } }
2.原理在Mybatis配置了
useGeneratedKeys="true" keyProperty="id"
insert into chart_page_panel ( `parent_id`, `position`, `name`, `create_time`, `create_user`, `last_modify_time`, `last_modify_user` ) values ( #{parentId}, #{position}, #{name}, NOW(), #{createUser}, NOW(), #{lastModifyUser} )
mybatis或者mybatis-plus中save方法返回主键值
1.mapper.xml中
方式:
useGeneratedKeys="true" keyProperty="id" keyColumn="id"
解释:
在xml中定义useGeneratedKeys为true,返回主键id的值,keyColumn和keyProperty分别代表数据库记录主键字段和java对象成员属性名
INSERT INTO adjust_bill_info(external_bill_id, warehouse_code, warehouse_name) VALUES(#{externalBillId}, #{warehouseCode}, #{warehouseName});
2.service或者dao中
注意:通过该种方式得到的结果是受影响的行数!!!!!
如果要获取主键id值,需要从传入的对象中获取!!!!!
Long id = aTranscationMapper.saveBill(adjustBillInfo);System.out.println("===========保存受影响的行数:"+id+" 保存的id值为:"+adjustBillInfo.getId());
输出结果展示:
===========保存受影响的行数:1 保存的id值为:191
mybatis-plus的insert后,返回主键id,直接通过传入的对象获取id即可!
bizApplicationFormMapper.insert(form);
System.out.println("=============="+form.getId());
以上是"mybatis如何实现新增save结束后自动返回主键id"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
对象
篇文章
影响
内容
实体
方式
结果
不怎么
代表
原理
场景
大部分
字段
属性
成员
数据
数据库
方法
更多
知识
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
战地4设置服务器
冀州区网络安全委员会
关于网络安全的一些主要问题
arma3怎么管理服务器
网络安全法国家安全法
有关数据库技术的参考文献
数据文件和数据库设计
mc如何限服务器3个管理员
公安网络安全工作目标
web前端连接数据库
共筑5g网络安全
山东职业学院计算机网络技术
画网络安全的画超简单
重庆网络营销网络技术服务哪家好
格家网络技术有限公司发展
app网络安全归程序员管吗
双绞线服务器
荒野日记连接不上服务器
网络安全存储服务器微信群
服务器下载统计
cs软件开发软件
ftp服务器超时
数据库 sa密码
我的世界服务器手机版推荐技能
互联网科技园区
数据库表里含有html标签
腾讯云服务器和阿里云
看懂网络安全
服务器 断电
c 数据库连接操作