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

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

创新互联服务电话:18982081108,为您提供成都网站建设网页设计及定制高端网站建设服务,创新互联网页制作领域十余年,包括成都茶艺设计等多个行业拥有多年设计经验,选择创新互联,为网站锦上添花。

在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里使用sqlsessiontemplate怎么获得刚插入的自增主键id
  • mybatis批量插入,怎么返回生成的自增主键

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

use 要查询的数据库

go

select * from information_schema.table_constraints

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

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

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

创新互联成都网站建设公司提供专业的建站服务,为您量身定制,欢迎来电(028-86922220)为您打造专属于企业本身的网络品牌形象。
成都创新互联品牌官网提供专业的网站建设、设计、制作等服务,是一家以网站建设为主要业务的公司,在网站建设、设计和制作领域具有丰富的经验。

本文名称:Mybatis如何获取数据库自增主键值(mybatis获取数据库自增主键值)
标题来源:http://www.shufengxianlan.com/qtweb/news47/269247.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联