mybatis返回插入数据的自增长id
来源:互联网 发布:mac excwl 改变语言 编辑:程序博客网 时间:2024/05/17 02:56
今天测试反馈一个bug,现象是新注册的用户可以看到所有人的报告,老用户没问题,查看日志发现原来查询的时候是新注册的用户的id为null,所以进行了全表有效数据查询。 但是表的主键不允许为空,怎么会出现新的注册用户id为null呢?原因是在service层代码直接将参数对象返回了,而xml没有做任何配置。
具体的解决方案是在xml中的insert方法配置
useGeneratedKeys=”true” keyProperty=”registerId”
keyProperty值对应实体VO对象中的主键属性
具体如下:
@Override public Registers create(Registers r) { registersMapper.insert(r); return r; }
registermapper.xml的insert方法如下:
<insert id="insert" parameterType="com.ciji.zzaservice.pojo.base.Registers" useGeneratedKeys="true" keyProperty="registerId">执行正常的insert语句</insert>
这样在controller层就可以得到新插入数据的自增长主键了。
关于在xml中添加两个属性的意思,网上解释如下:
useGeneratedKeys
(仅对insert有用)这会告诉MyBatis使用JDBC的getGeneratedKeys方法来取出由数据(比如:像MySQL和SQL Server这样的数据库管理系统的自动递增字段)内部生成的主键。默认值:false。
keyProperty
(仅对insert有用)标记一个属性,MyBatis会通过getGeneratedKeys或者通过insert语句的selectKey子元素设置它的值。默认:不设置。
0 0
- mybatis返回插入数据的自增长id
- mybatis insert插入返回自增长id
- mybatis中插入数据自动返回自增长id的配置
- iBATIS插入数据返回自增长ID
- myBatis+mysql获取插入数据的自增长id
- mybaties+oracle:插入数据,返回自增长的id
- mybaties+mysql:插入数据,返回自增长的id
- mybatis插入数据时设置id自增长
- Mybatis id自增,插入数据后返回id
- Mybatis获取插入记录的自增长ID
- MyBatis获取插入记录的 id 自增长字段值
- Mybatis获取插入记录的自增长ID
- Mybatis获取插入记录的自增长ID
- Mybatis获取插入记录的自增长ID
- Mybatis获取插入记录的自增长ID
- Mybatis获取插入记录的自增长ID
- Mybatis获取插入记录的自增长ID
- Mybatis获取插入记录的自增长ID
- 错误解决:ORA-01036
- 深入浅出MFC笔记
- 17个提升iOS开发效率的必用工具
- (NO.00003)iOS游戏简单的机器人投射游戏成形记(十四)
- live555
- mybatis返回插入数据的自增长id
- adb的端口被占用问题
- 射频识别技术漫谈(21)——RC系列射频芯片的天线设计
- Linux内核模块添加的两种方法
- 【Oracle】Oracle 12c DB In-Memory入门实验手册(二)
- java 动态代理学习(Proxy,InvocationHandler)
- hadoop2.2伪分布式安装
- C#中Config文件中,特殊符号的书写方法。
- Zookeeper--Zookeeper是什么