您的位置:首页 > 其它

mybatis返回插入数据的自增长id

2015-11-13 17:04 471 查看
今天测试反馈一个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子元素设置它的值。默认:不设置。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息