你好,我的mongoDB素要获取最新插入记录的id,请问该怎么实现呢?请帮帮小弟,谢谢了

 我来答
sniper2003
2012-08-22 · TA获得超过1882个赞
知道小有建树答主
回答量:775
采纳率:100%
帮助的人:660万
展开全部
获取最新,要看你如何定义“最新”这个名词。

一般情况下,设定的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列的值就可以了。
来自:求助得到的回答
Storm代理
2023-07-25 广告
StormProxies是一家可靠的代理服务提供商,提供原生IP(住宅原生IP)和高匿名代理服务。以下是关于StormProxies的原生IP服务的一些信息:1. 住宅原生IP:StormProxies提供的住宅原生IP是指从真实的家庭或企... 点击进入详情页
本回答由Storm代理提供
hsgbuy
2012-12-27
知道答主
回答量:3
采纳率:0%
帮助的人:4459
展开全部
Id = ObjectId.GenerateNewId();
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式