首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mybatis 实时获取数据库的自增id

前言 在日常业务处理中,我们难免需要立马用到刚刚插入数据库数据的id,如果我们的id并不是我们插入的(例如uuid,雪花算法得到的等),而是数据库自增的,我们便无法得知次id是多少,如果我们再次查询数据库获取该...id,属实是写复杂了,并且还再次访问了数据库,有些多此一举,但mybatis给我们提供了一种方法以便我们来获取到该id,接下来就让我们来一探究竟吧 业务复现 现在我们有一张用户表,一张角色表,一张用户角色中间表...,我们需要新建用户的时候给用户赋予角色,这个时候便需要在用户表插入数据时获取到该用户的id 我们正常来写的话代码如下: (简单复现一下代码) 实现类 @Override public void...="insertDept"> insert into dept (dept_id,user_id) values (#{deptId},#{userId}) ...这样子写会有报错,提示我们userId不能为空,这就说明我们无法获取到新加入用户的id 解决方案 在user.xml加入两个参数 useGeneratedKeys keyProperty useGeneratedKeys

10210
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mybatis获取update的id

    这样我门就进行了两次数据库操作,链接了两次数据库。增加了接口的处理事件,因为链接数据库是很耗时的操作。 其实可以通过 mybatis 的 selectKey 标签来解决这个问题。 ...此处用法用法就是当 insert into 执行后 执行 selectKey 的内容将数据库的最后一个id 查询出来映射到传入数据对像的ID 属性。...写更新语句,并将更新的纪录的ID 返回出来。 通过 test 的name 去更新 test 的email,并获取被更新纪录的id。...WHERE name =#{name} 上述代码就是通过 selectKey 实现了 通过 test 的name 去更新 test 的email,并获取被更新纪录的...SELECT     (select id FROM test WHERE     name = #{name})id from DUAL  此 SELECT 就是为了获取 被更新的 test的

    3.8K60

    mybatis获取update的id

    这样我门就进行了两次数据库操作,链接了两次数据库。增加了接口的处理事件,因为链接数据库是很耗时的操作。 其实可以通过 mybatis 的 selectKey 标签来解决这个问题。 ...此处用法用法就是当 insert into 执行后 执行 selectKey 的内容将数据库的最后一个id 查询出来映射到传入数据对像的ID 属性。 写更新语句,并将更新的纪录的ID 返回出来。...通过 test 的name 去更新 test 的email,并获取被更新纪录的id。...WHERE name =#{name} 上述代码就是通过 selectKey 实现了 通过 test 的name 去更新 test 的email,并获取被更新纪录的...SELECT     (select id FROM test WHERE     name = #{name})id from DUAL  此 SELECT 就是为了获取 被更新的 test的id 外边包装一个虚表查询是当

    9.3K80

    mybatis获取update的id

    这样我门就进行了两次数据库操作,链接了两次数据库。增加了接口的处理事件,因为链接数据库是很耗时的操作。 其实可以通过 mybatis 的 selectKey 标签来解决这个问题。 ...此处用法用法就是当 insert into 执行后 执行 selectKey 的内容将数据库的最后一个id 查询出来映射到传入数据对像的ID 属性。 写更新语句,并将更新的纪录的ID 返回出来。...通过 test 的name 去更新 test 的email,并获取被更新纪录的id。...WHERE name =#{name} 上述代码就是通过 selectKey 实现了 通过 test 的name 去更新 test 的email,并获取被更新纪录的...SELECT     (select id FROM test WHERE     name = #{name})id from DUAL  此 SELECT 就是为了获取 被更新的 test的id 外边包装一个虚表查询是当

    3.4K20

    职教云教师ID获取教程

    首先呢,因为这个教师ID在多个地方都有出现,但是每个老师的活动情况都不一样,所以也就没有写到软件里了(好吧,我就是懒)。然后修改作业时间呀,作业分数呀都需要用到这个ID,所以这里写一下获取教程。...方法一:通过课件获取 打开职教云网站,点开要获取的老师的课程, 打开F12,切换到NetWork栏。点击XHR。 进入课件!!!!注意!!!...进入课件,也就是需要播放课件,可以看到一个getCellCommentData,这个就是教师ID了 方法二:通过课后获取 进入课堂,课堂教学,课后,找到课后任务 打开F12,切换到NetWork栏...点击详情,可以看到一个getFaceTechRequireinfo,红框框里面的就是教师ID 方法三,好吧,懒得写了,有上面两个就够了

    3.8K10

    Go: 获取系统用户id示例

    本文将深入探讨 Go 语言中获取操作系统用户信息的两种常见情境:获取当前用户的信息以及获取指定用户的信息。 获取当前用户的信息 在很多应用程序中,我们需要知道当前正在运行程序的用户是谁。...currentUser.Uid) } 这段代码首先导入必要的包,然后通过 user.Current() 函数获取当前用户的信息。...获取指定用户名的用户信息 除了获取当前用户信息外,有时我们还需要根据用户名来获取特定用户的信息。Go 的 os/user 包同样支持这一操作,通过 Lookup 函数实现。...实际应用 在实际应用中,这两种方法可以帮助开发者在需要时快速有效地获取用户信息。例如,在处理文件权限、管理用户配置文件或实现基于用户的服务时,这些信息至关重要。...无论是获取当前用户信息还是查找特定用户信息,Go 都提供了直接且易于理解的方法。作为开发者,熟练掌握这些技能将在你的编程旅程中大有裨益。 以上就是关于在 Go 语言中获取操作系统用户信息的探讨。

    17410

    php 获取连续id,WordPress文章ID连续及ID重新排列的方法

    解决Wordpress 文章 ID连续问题,同时让Wordpress 文章 ID重新排列。在用以下方法前,先备份好网站文件和数据库文件,以免操作不当造成损失。...不过我只是看见ID不连续不爽,典型ID控^_^BUG:发布文章、页面后都会跳转到文章列表。如果以前Wordpress发表过文章造成ID不连续,我想让ID连续有什么办法,当然有咯。...请看让Wordpress文章ID重新排列的方法介绍。 前面我们介绍过让Wordpress文章ID连续的方法,如果以前Wordpress发表过文章造成ID不连续,我想让ID连续有什么办法,当然有咯。...备注:其实之所以不连续的原因是里面有草稿 如何区分草稿和正式的文章,数据库里面有个post_status  值为publish就是正式的文章 未经允许不得转载:肥猫博客 » php 获取连续id,WordPress...文章ID连续及ID重新排列的方法

    9.2K40

    Mybatis获取自增长的主键id

    1.前言 这个问题主要是今天项目中新加的一个需求导致的,主要过程是这样的,因为每个项目里面用户,角色,权限这三者是密不可分的,在数据库中就可以通过下面这张图来表达他们三者之间的关系: ?...user与role两者关联起来呢,要知道我们关联user与role就是将user的主键userId与role的主键roleId插入到user-role这个关联表中,之前因为我们是先创建在分配,所以完全可以获取到用户的...userId,但是现在是要在创建的时候就分配,又因为我们的userId是在数据库中设置的自动增长,所以前端传给我们的user对象里面是不包含userId的....,一个是执行插入操作之后再取出主键Id.前者使用与自己定义的自增长规则的id,后者就是用与我们的情况即自增长的id 小栗子: <insert id="insertSelective" parameterType...数据库中用户数据成功插入 ? 我们再去看看user-role里面的数据插入了没有 ?

    3.4K20

    Android根据资源名获取资源ID

    接触过Android开发的同学们都知道在Android中访问程序资源基本都是通过资源ID来访问。这样开发起来很简单,并且可以不去考虑各种分辨率,语言等不同资源显式指定。...痛点 但是,有时候也会有一些问题,比如我们根据服务器端的值取图片,但是服务器端绝对不会返回给我们的是资源id,最多是一种和文件名相关联的值,操作资源少的时候,可以维护一个容器进行值与资源ID的映射,但是多的话...便捷的方法 在这种情况下,使用文件名来得到资源ID显得事半功倍。 通过调用Resources的getIdentifier可以很轻松地得到资源ID。...imageResIdByAnotherForm = 2130837504;musicResId=2130968576;notFoundResId =0 看一看API 直接API 这个方法用来使用资源名来获取资源...defType和defPackage省略时,需要将其设置成null 注意这个方法不提倡,因为直接通过资源ID访问资源会更加效率高 如果资源没有找到,返回0,在Android资源ID中0不是合法的资源ID

    3.5K10
    领券