Mybatis如何获取数据库自增主键值 (mybatis 获取数据库自增主键值) (mybatis框架)

技术教程 2025-05-12 09:49:20 浏览

Mybatis是一种开源的Java持久层框架,它能够将Java对象映射到关系型数据库中。Mybatis的主要功能是将SQL语句和Java代码分开,使得开发人员能够更加专注于Java代码的编写,而不用去关心SQL语句的具体实现。

在Mybatis中,数据库中的自增主键(auto_increment)是非常常见的一种数据类型。当我们在插入数据时,通常需要获取新插入数据的主键值。本文将介绍如何在Mybatis中获取数据库中的自增主键。

一、设置主键生成策略

在Mybatis的映射文件中,我们需要设置主键生成策略,以告诉Mybatis如何生成主键。

在标签中,我们可以使用子标签来设置主键生成策略。该子标签有三个属性:

1. keyProperty:指定Java对象中哪个属性应该被赋值为主键值。

2. order:指定SELECT语句的执行顺序。有两个可选值:BEFORE和AFTER。如果order的值为BEFORE,则先执行SELECT语句,再执行INSERT语句。如果order的值为AFTER,则先执行INSERT语句,再执行SELECT语句。

3. resultType:指定SELECT语句的返回值类型。

下面是一个使用子标签的例子:

SELECT LAST_INSERT_ID()

INSERT INTO user(name, age) VALUES(#{name}, #{age})

上面的例子中,我们使用LAST_INSERT_ID()函数获取自增主键值。LAST_INSERT_ID()是MySQL中的一个函数,它返回最后一次插入操作产生的自增主键值。使用LAST_INSERT_ID()函数能够保证线程安全,因为该函数只会返回当前会话(session)中最后一次插入操作的自增主键值。

二、使用getGeneratedKeys方法

在Java的JDBC中提供了一个getGeneratedKeys方法,该方法能够获取自增主键的值。我们可以在Mybatis中使用getGeneratedKeys方法来获取数据库中的自增主键。

在标签中,我们需要添加useGeneratedKeys属性,并将其设置为true。这样就可以启动JDBC驱动程序的自动生成键机制。在执行INSERT语句后,我们可以通过PreparedStatement的getGeneratedKeys()方法来获取自增主键的值。

下面是一个使用getGeneratedKeys方法的例子:

keyProperty=”id”>

INSERT INTO user(name, age) VALUES(#{name}, #{age})

在上面的例子中,我们将useGeneratedKeys属性设置为true,并指定keyProperty属性为id。当执行INSERT语句后,Mybatis会获取数据库中的自增主键值,并将其设置到Java对象中的id属性中。

三、

在Mybatis中获取数据库中的自增主键值,有两种方法:一种是使用子标签,从而使用LAST_INSERT_ID()函数获取自增主键值;另一种是使用getGeneratedKeys方法,直接从JDBC驱动程序中获取自增主键值。两种方法均有其优缺点,需要开发人员根据实际情况进行选择。

相关问题拓展阅读: Mybatis如何获取数据库自增主键值my

mybatis里使用sqlsessiontemplate怎么获得刚插入的自增主键id

use 要查询的数据库

select * from information_schema.table_constraints

mybatis批量插入,怎么返回生成的自增主键

其次4的方式返回值只是成功与否的状态,不是自增主键。只不过采用了这种方式之后自增主键会被mybatis赋给do,这样可以直接使用do.getid()得到插入后的主键

关于mybatis 获取数据库自增主键值的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

香港服务器首选树叶云,2H2G首月10元开通。树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云 服务器 和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。


Java软件工程师主要学习哪些课程?

第一阶段,Java SE基础:

Java环境搭建、Java流程控制语句-for循环、switch选择判断、循环嵌套、数组bai拷贝、多维数组、final关键字、构造函数的调用、类的访问权限和路径、面向对象高级特性、Java异常处理、Set,Map,List接口及接口实现类、Java线程、同步阻塞、JavaIO流、文件的操作,复制,读写,删除等。

第二阶段,JavaWeb

MySQL安装、管理、创建数据库、MySQLUPDATE 查询、Mysql高级操作、JDBC、JDBC数据库连接操作,JDBC动态Sql处理、Servlet3.0网页重定向、Servlet3.0 新增的注解支持、AJAX、responseText属性详解等。

第三阶段,Java高级框架-SSH:

Struts2异常处理、Struts2+Log4j集成、Struts2和JSON实例、Hibernate5、Hibernate集合映射、Hibernate组件映射、Spring4.0、SpringAOP+ AspectJ框架、Spring 与其它Web框架集成、Spring Hibernate支持等。

第四阶段,Java高级框架-SSM:

SpringMVC、Spring MVC生成JSON数据、MyBatis、MyBatis 环境配置及入门、Mybatis set标签、Mybatis trim标签、Shiro、Shiro快速入门教程、Shiro Web应用等。

无法访问 G:\. 系统无法在消息文件中为 G:\ 找到消息号为 0x 的消息文本。 这是什么意思啊?怎么解决

;官方默认激活法:说是“官方”默认“激活”方法一点都没错,因为这个方法根本不是真正的激活了我们的windows7,而是让我们的试用时间延长。 具体操作:打开附件—–命令提示符。 (注意要使用右键管理员方式运行)。 在命令行中输入“/rearm”的命令延长使用期30天重启系统后,又恢复到30天。 请注意!一定要等到出现提示字样,然后重启系统。 加强版操作:上面的方法3次后,共计120天后,此后将无法再次使用。 就要进行下一步,修改注册表中的一处键值,即可重复使用上面的命令,请打开注册表编辑器,依次定位至“HKEY_LOCAL_MACHINESOFTWAREMicrosoftWindowsNTCurrentVersionSoftwareProtectionPlatform”。 找到右侧窗格中的“SkipRearm”,将其键值修改为“1”,以后就可以再次使用“ /rearm”的命令,这个键值总共可以修改8次,也就是说我们可以重复使用8次“/rearm”的命令。 因此可以免费使用的时间为:初次安装的30天,加slmgr首次的3次90天,然后8次修改注册表的240天。 Win7 竟然可以“免费”使用360天!!(据说这个方法在VISTA刚出的时候就有了)你试试看这个方法,看看能不能激活。

MyBatis 读取 Mysql Blob类型的SQL怎么写

MySQL中的blob,mediumblob,longblob 可以映射到mybatis中 的byte[] 类型 ,需要mybatis的 类型转换处理器的支持。

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐