广告
返回顶部
首页 > 资讯 > 后端开发 > Python >MyBatis获取自动生成的(主)键值的方法
  • 129
分享到

MyBatis获取自动生成的(主)键值的方法

MyBatis获取自动生成键值MyBatis获取键值 2023-05-15 08:05:14 129人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

mybatis中insert 方法总是返回一个int值 ,这个值代表的是插入所影响的行数。 如果id采用自增长策略,自动生成的键值在 insert 方法执行完后可以被设置到传入的参数

mybatis中insert 方法总是返回一个int值 ,这个值代表的是插入所影响的行数。 如果id采用自增长策略,自动生成的键值在 insert 方法执行完后可以被设置到传入的参数对象中。那么我们可以在service中通过传入的对象来获得插入的id值。

mapper.xml文件

 <insert id="insert" keyColumn="id" keyProperty="id" parameterType="com.woniuxy.SpringBootmybatis.entity.User" useGeneratedKeys="true">
        insert into user
        ( id,user_name,tel
        ,passWord,age,create_date
        ,head_img,dept_id)
        values (#{id,jdbcType=INTEGER},#{userName,jdbcType=VARCHAR},#{tel,jdbcType=VARCHAR}
        ,#{password,jdbcType=VARCHAR},#{age,jdbcType=INTEGER},#{createDate,jdbcType=TIMESTAMP}
        ,#{headImg,jdbcType=VARCHAR},#{deptId,jdbcType=INTEGER})
    </insert>

service代码

 @Override
    public int insertSelective(User record) {
        int result = userMapper.insertSelective(record);
        log.info("当前行数据的ID为{}",record.getId());
        return result;
    }

日志文件为:

2023-04-06 15:45:09.813  INFO 15952 --- [NIO-8080-exec-1] c.w.s.service.impl.UserServiceImpl       : 当前行数据的ID为107

非自增长的主键

<insert id="add" parameterType="user">
    <selecTKEy keyProperty="id" order="BEFORE" resultType="string">
        select uuid()
    </selectKey>
    insert into questions (id,title) values(#{id},#{title})
</insert>
  • insert入参填充、返回值不变
    • 返回值还是Integer受影响的行数
    • 入参的user中也会注入主键值
  • selectKey :将执行结果注入到user的属性中
  • keyProperty:注入的user中主键对应的属性
  • order
    • BEFORE:selectKey在insert之前执行,一般为uuid、序列,此时执行结果已注入到user属性中,再执行insert时,使用#{id}即为selectKey注入的值
    • AFTER:selectKey在insert之后执行,一般为自增主
  • resultType:selectKey中执行sql的返回结果类型

到此这篇关于MyBatis获取自动生成的(主)键值的方法的文章就介绍到这了,更多相关MyBatis获取自动生成键值内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: MyBatis获取自动生成的(主)键值的方法

本文链接: https://www.lsjlt.com/news/208523.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作