代码改变世界

mongodb - collMod

  abce  阅读(1214)  评论(0编辑  收藏  举报

该方法给集合添加一个标识,来修改集合的行为。 标识包含usePowerOf2Sizes和index。

命令格式为:

1
db.runCommand({"collMod":<collection>,"<flag>":<value>})

 

检查标记设置:db.collection.stats()结果中的userFlags

 

1.通过collMod的标记修改TTL集合的过期时间:
#创建TTL集合

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
> db.log_events.createIndex({"createdAt": 1},{expireAfterSeconds: 360})
{
        "createdCollectionAutomatically" : true,
        "numIndexesBefore" : 1,
        "numIndexesAfter" : 2,
        "ok" : 1
}
> db.log_events.insert({
    "createdAt": new Date(),
    "logEvent": 2,
    "logMessage": "Success!"
    })
WriteResult({ "nInserted" : 1 })
> db.log_events.find()
{ "_id" : ObjectId("56e4d6b51f83a0ff9e45be1c"), "createdAt" : ISODate("2016-03-13T02:55:49.002Z"), "logEvent" : 2, "logMessage" : "Success!" }

#查看TTL索引信息

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
> db.log_events.getIndexes()
[
        {
                "v" : 1,
                "key" : {
                        "_id" : 1
                },
                "name" : "_id_",
                "ns" : "test.log_events"
        },
        {
                "v" : 1,
                "key" : {
                        "createdAt" : 1
                },
                "name" : "createdAt_1",
                "ns" : "test.log_events",
                "expireAfterSeconds" : 360
        }
]

#使用collMod修改TTL过期时间
#格式为{keyPattern: <TTL索引>, expireAfterSeconds: <修改后的过期时间> }

1
2
3
4
5
6
7
8
9
> db.runCommand({collMod: 'log_events', index: {keyPattern:{createAt:1}, expireAfterSeconds:800}})
{
        "ok" : 0,
        "errmsg" : "cannot find index { createAt: 1.0 } for ns test.log_events",
        "code" : 72
}
> db.runCommand({collMod: 'log_events', index: {keyPattern:{createdAt:1}, expireAfterSeconds:800}})
{ "expireAfterSeconds_old" : 360, "expireAfterSeconds_new" : 800, "ok" : 1 }
>

 

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示