问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

mysql数据库怎么获取到自增长id

发布网友 发布时间:2022-04-08 06:36

我来回答

2个回答

懂视网 时间:2022-04-08 10:57

SELECT LAST_INSERT_ID();

    产生的ID 每次连接后保存在服务器中。这意味着函数向一个给定客户端返回的值是该客户端产生对影响AUTO_INCREMENT列的最新语句第一个 AUTO_INCREMENT值的。这个值不能被其它客户端影响,即使它们产生它们自己的 AUTO_INCREMENT值。这个行为保证了你能够找回自己的 ID 而不用担心其它客户端的活动,而且不需要加锁或处理。
 
    每次mysql_query操作在mysql服务器上可以理解为一次“原子”操作, 写操作常常需要锁表的, 是mysql应用服务器锁表不是我们的应用程序锁表。
 
    值得注意的是,如果你一次插入了多条记录,这个函数返回的是第一个记录的ID值。
    因为LAST_INSERT_ID是基于Connection的,只要每个线程都使用独立的Connection对象,LAST_INSERT_ID函数 将返回该Connection对AUTO_INCREMENT列最新的insert or update*作生成的第一个record的ID。这个值不能被其它客户端(Connection)影响,保证了你能够找回自己的 ID 而不用担心其它客户端的活动,而且不需要加锁。使用单INSERT语句插入多条记录,  LAST_INSERT_ID返回一个列表。
    LAST_INSERT_ID 是与table无关的,如果向表a插入数据后,再向表b插入数据,LAST_INSERT_ID会改变。
 
方法二:是使用max(id)
 
使用last_insert_id是基础连接的,如果换一个窗口的时候调用则会一直返回10
如果不是频繁的插入我们也可以使用这种方法来获取返回的id值

select max(id) from user;

这个方法的缺点是不适合高并发。如果同时插入的时候返回的值可能不准确。
 
方法三:是创建一个存储过程,在存储过程中调用先插入再获取最大值的操作

DELIMITER $$
DROP PROCEDURE IF EXISTS `test` $$
CREATE DEFINER=`root`@`localhost` PROCEDURE `test`(in name varchar(100),out oid int)
BEGIN
 insert into user(loginname) values(name);
 select max(id) from user into oid;
 select oid;
END $$
DELIMITER ;
call test(‘gg‘,@id);

方法四:使用@@identity

select @@IDENTITY

    @@identity是表示的是最近一次向具有identity属性(即自增列)的表插入数据时对应的自增列的值,是系统定 义的全局变量。一般系统定义的全局变量都是以@@开头,用户自定义变量以@开头。比如有个表A,它的自增列是id,当向A表插入一行数据后,如果插入数据 后自增列的值自动增加至101,则通过select @@identity得到的值就是101。使用@@identity的前提是在进行insert操作后,执行select @@identity的时候连接没有关闭,否则得到的将是NULL值。

方法五:是使用getGeneratedKeys()

Connection conn = ;
Serializable ret = null;
PreparedStatement state = .;
ResultSet rs=null;
try {
 state.executeUpdate();
 rs = state.getGeneratedKeys();
 if (rs.next()) {
 ret = (Serializable) rs.getObject(1);
 } 
} catch (SQLException e) {
}
return ret;

总结一下,在mysql中做完插入之后获取id在高并发的时候是很容易出错的。另外last_insert_id虽然是基于session的但是不知道为什么没有测试成功。
     
    其实在ibtias框架里使用selectkey这个节点,并设置insert返回值的类型为integer,就可以返回这个id值。
    

mysql插入数据后返回自增ID的方法

标签:

热心网友 时间:2022-04-08 08:05

在MySQL中,使用auto_increment类型的id字段作为表的主键,并用它作为其他表的外键,形成“主从表结构”,这是数据库设计中常见的用法。但是在具体生成id的时候,我们的操作顺序一般是:先在主表中插入记录,然后获得自动生成的id,以它为基础插入从表的记录。这里面有个困难,就是插入主表记录后,如何获得它对应的id。通常的做法,是通过“select max(id) from tablename”的做法,但是显然这种做法需要考虑并发的情况,需要在事务中对主表加以“X锁“,待获得max(id)的值以后,再解锁。这种做法需要的步骤比较多,有些麻烦,而且并发性也不好。有没有更简单的做法呢?答案之一是通过select LAST_INSERT_ID()这个操作。乍一看,它和select max(id)很象,但实际上它是线程安全的。也就是说它是具体于数据库连接的。下面通过实验说明:

1、在连接1中向A表插入一条记录,A表包含一个auto_increment类型的字段。

2、在连接2中向A表再插入一条记录。

3、结果:在连接1中执行select LAST_INSERT_ID()得到的结果和连接2中执行select LAST_INSERT_ID()的结果是不同的;而在两个连接中执行select max(id)的结果是相同的。

其实在MSSQL中SCOPE_IDENTITY()和IDENT_CURRENT()的区别和这里是类似的。使用SCOPE_IDENTITY()可以获得插入某个IDENTITY字段的当前会话的值,而使用IDENT_CURRENT()会获得在某个IDENTITY字段上插入的最大值,而不区分不同的会话。

注:使用select last_insert_id()时要注意,当一次插入多条记录时,只是获得第一次插入的id值,务必注意!可以试试

insert into tb(c1,c2) values (c1value,c2value),(c1value1,c2value2)..。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
临沂比较有名的男装品牌 呼伦贝尔市悦动网络科技有限公司怎么样? 呼伦贝尔中汇实业有限公司怎么样? 呼伦贝尔油玉不绝电子商务有限公司怎么样? 如何避免wps卡顿? 属鼠的男人找对象是属什么,属鼠的人和什么属相合 96年鼠的姻缘在哪年 属相相合年份运势提升 2024属鼠找对象属什么最佳 黑客攻击网站能报案吗 黑客攻击报案有用吗 养蚯蚓需要注意些什么? 试述蚯蚓有哪些方面适应土壤穴居生活 大规模养殖蚯蚓应该选择什么样的场地,非诚勿扰 养蚯蚓的土须要什么样的湿度啊! 什么样的土质适合养蚯蚓 对于蚯蚓养殖有何环境要求? 晚上好,养殖蚯蚓对场地有什么要求? 养蚯蚓用什么土 蚯蚓一般生活在什么土壤中 蚯蚓喜欢生活在什么样的土壤? 挂满红灯笼的地方是什么地方 灯笼从哪里买 html中 <dl> </dl> 代码是是什么代码? 什么是DL图?? dl等于多少毫升 请问麦当劳DL的DL是什么意思啊? 1 dl 是多少升? dl 是分升吗? 炫舞里的人老说DL,DL是什么意思 魔力宝贝传教士职业三阶进阶怎么过 魔力宝贝怎么3转? 单宽带和家庭宽带区别 单宽带和宽带有什么区别? 单位宽带和家庭宽带有何区别 家庭宽带和宽带区别 移动的单宽带,融合宽带,家庭宽带都是什么意思啊?有什么不同啊? 中国移动和家庭和单宽带的区别 家庭单宽带怎么收费 电信办理家庭宽带的单宽 无绑定的 哪一个宽带比较好? 家里装宽带单装和手机绑定,哪个更好? 什么是家庭单产品宽带包月版? 荣耀手机优优这设置? HONOR9A怎么样随时能够呼叫YOYO? 手机荣耀9 i yoyo怎么召唤? 跪求同人卡通动漫,【在线观看】免费百度云资源 求以前播放的过卡通动漫 谁有在线观看卡通的清晰网站,清晰,清晰。 这是什么卡通片? 求东北地三鲜的做法,正宗东北地三鲜怎么做好? 东北地三鲜怎么做? 东北地三鲜怎么做好吃