在 MongoDB 中创建整数类型的唯一索引
Creating unique index in MongoDB with type integer
我想创建一个简单的集合来存储不同设备的统计信息。
每个设备都有一个唯一的设备 ID。我想强制唯一性,所以我想为设备 id 字段创建一个唯一索引,但我没有想出如何告诉集合这个字段是数字类型。
例如,我可以接收设备 ID 为“0x3f”、“0x0003f”、“3f”...的查询,并且所有这些都需要匹配同一个文档。
我可以在查询数据库之前解析请求,但对我来说这听起来不是正确的解决方案...
我建议 不要 在 Mongo 中担心这个问题,而是尝试在调用 Mongo 的应用层中处理它。例如,在 JavaScript 中,欣赏使用任何十六进制文字转换为相同的整数值:
var i = 0x3f;
var j = 0x0003f;
if (i == 63) {
console.log("0x3f = 63");
}
if (j == 63) {
console.log("0x0003f = 63");
}
也就是说,让应用程序将十六进制文字编组为整数值,然后将该 int 值传递给 Mongo。
我想创建一个简单的集合来存储不同设备的统计信息。 每个设备都有一个唯一的设备 ID。我想强制唯一性,所以我想为设备 id 字段创建一个唯一索引,但我没有想出如何告诉集合这个字段是数字类型。
例如,我可以接收设备 ID 为“0x3f”、“0x0003f”、“3f”...的查询,并且所有这些都需要匹配同一个文档。 我可以在查询数据库之前解析请求,但对我来说这听起来不是正确的解决方案...
我建议 不要 在 Mongo 中担心这个问题,而是尝试在调用 Mongo 的应用层中处理它。例如,在 JavaScript 中,欣赏使用任何十六进制文字转换为相同的整数值:
var i = 0x3f;
var j = 0x0003f;
if (i == 63) {
console.log("0x3f = 63");
}
if (j == 63) {
console.log("0x0003f = 63");
}
也就是说,让应用程序将十六进制文字编组为整数值,然后将该 int 值传递给 Mongo。