源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

MyBatis获取插入记录的自增长字段值(ID)

  • 时间:2020-08-04 00:30 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:MyBatis获取插入记录的自增长字段值(ID)
[b]第一步:[/b]     在Mybatis Mapper文件中添加属性“[code]useGeneratedKeys[/code]”和“[code]keyProperty[/code]”,其中[code]keyProperty[/code]是Java对象的属性名!
<insert id="insert" parameterType="Spares" 
 useGeneratedKeys="true" keyProperty="id">
 insert into spares(spares_id,spares_name,
  spares_type_id,spares_spec)
 values(#{id},#{name},#{typeId},#{spec})
 </insert>
[b]第二步:[/b]     Mybatis执行完插入语句后,自动将自增长值赋值给对象Spares的属性id。因此,可通过Spares对应的getter方法获取!
 /**
 * 新增备件
 * @author hellostory
 * @param spares
 * @return
 */
 @RequestMapping(value = "/insert")
 @ResponseBody
 public JsonResponse insert(Spares spares) {
 int count = sparesService.insert(spares);
 System.out.println("共插入" + count + "条记录!"
  + "\n刚刚插入记录的主键自增长值为:" + spares.getId());
[b]ps:mybatis返回插入数据的自增长id[/b] 今天测试反馈一个bug,现象是新注册的用户可以看到所有人的报告,老用户没问题,查看日志发现原来查询的时候是新注册的用户的id为null,所以进行了全表有效数据查询。 但是表的主键不允许为空,怎么会出现新的注册用户id为null呢?原因是在service层代码直接将参数对象返回了,而xml没有做任何配置。 具体的解决方案是在xml中的insert方法配置
useGeneratedKeys=”true” keyProperty=”registerId”
keyProperty值对应实体VO对象中的主键属性 具体如下:
<code class="hljs java">@Override
  public Registers create(Registers r) {
    registersMapper.insert(r);
    return r;
  }</code>
registermapper.xml的insert方法如下:
<code class="hljs xml"><insert id="insert" keyproperty="registerId" parametertype="com.ciji.zzaservice.pojo.base.Registers" usegeneratedkeys="true">
执行正常的insert语句
</insert></code>
这样在controller层就可以得到新插入数据的自增长主键了。 关于在xml中添加两个属性的意思,网上解释如下: [b]useGeneratedKeys[/b] (仅对insert有用)这会告诉MyBatis使用JDBC的getGeneratedKeys方法来取出由数据(比如:像MySQL和SQL Server这样的数据库管理系统的自动递增字段)内部生成的主键。默认值:false。 [b]keyProperty[/b] (仅对insert有用)标记一个属性,MyBatis会通过getGeneratedKeys或者通过insert语句的selectKey子元素设置它的值。默认:不设置。 [b]总结[/b] 以上所述是小编给大家介绍的MyBatis获取插入记录的自增长字段值(ID),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部