欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-04-01 18:42:52
第一步:     在mybatis mapper文件中添加属性“usegeneratedkeys”和“keyproperty”,其中keyp...

第一步:

    在mybatis mapper文件中添加属性“usegeneratedkeys”和“keyproperty”,其中keyproperty是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>

第二步:

    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());

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

今天测试反馈一个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中添加两个属性的意思,网上解释如下:

usegeneratedkeys

(仅对insert有用)这会告诉mybatis使用jdbc的getgeneratedkeys方法来取出由数据(比如:像mysql和sql server这样的数据库管理系统的自动递增字段)内部生成的主键。默认值:false。

keyproperty

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

总结

以上所述是小编给大家介绍的mybatis获取插入记录的自增长字段值(id),希望对大家有所帮助