频道栏目
首页 > 程序开发 > 综合编程 > 其他综合 > 正文
mybatis返回插入数据的自增长id
2015-11-16 13:40:29      个评论    来源:你究竟是想一辈子卖糖水,还是希望获得改变世界的机会?  
收藏   我要投稿

今天测试反馈一个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语句

这样在controller层就可以得到新插入数据的自增长主键了。
关于在xml中添加两个属性的意思,网上解释如下:
useGeneratedKeys
(仅对insert有用)这会告诉MyBatis使用JDBC的getGeneratedKeys方法来取出由数据(比如:像MySQL和SQL Server这样的数据库管理系统的自动递增字段)内部生成的主键。默认值:false。

keyProperty
(仅对insert有用)标记一个属性,MyBatis会通过getGeneratedKeys或者通过insert语句的selectKey子元素设置它的值。默认:不设置。

点击复制链接 与好友分享!回本站首页
相关TAG标签 数据
上一篇:[数据结构]二叉树
下一篇:遍历文件并格式化输出文件(shell脚本实现)
相关文章
图文推荐
点击排行

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站