SQL触发器获取刚插入ID

SQL触发器获取刚插入ID,第1张

create table info

(

id int identity primary key,

[name] varchar(10)

)

go

create trigger trig_insert

on info for insert

as

begin

declare @id int

select @id=id from inserted

print @id

end

insert into info values('123')

获取最新,要看你如何定义“最新”这个名词。

一般情况下,设定的BsonId是默认类型的(也就是你在你在shell中看到的BsonId('xxxxxxxxxxxxx')这一列的数字)。BsonId类型中没几位都代表着不同的含义,其中有一列是就是按照机器的时间来定义的。所以,在默认BsonId作为主键的时候,可以直接倒叙BsonId的列,然后取出1条就行了。

其他情况,你可以设置一个时间列,并设置好索引。然后倒叙取1条即可。

你说的获取最新记录,是不是像t-sql中下面的语句:

insert into TABLE(values);

select @id = scope_identity() from TABLE

如果是这样的,那么mongodb是没有提供直接获取id的方式的。需要你自己编写逻辑来实现,具体实现思路如下:

1、首先创建一张id生成集合Collection,这个集合专门用来生成id;

2、当你需要向其他集合中插入一条需要返回id的记录时,先从上面那张集合中插入一个id(因为你知道插入id的值,所以不涉及插入后取出的问题),然后将这个id赋值给插入业务集合的那个数据的id列中;

这里有一个你需要注意的地方,就是向id生成列中,应该插入什么值才最合适?因为这个值的插入也涉及到这个表的性能。Mongodb中提供列+1的 *** 作,所以你只需要使用FindAndModify方法来获取一个+1后的id列的值就可以了。

以上就是关于SQL触发器获取刚插入ID全部的内容,包括:SQL触发器获取刚插入ID、你好,我的mongoDB素要获取最新插入记录的id,请问该怎么实现呢请帮帮小弟,谢谢了、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9323428.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存