gpt4 book ai didi

java - Spring Data MongoDB 索引(唯一=真)

转载 作者:塔克拉玛干 更新时间:2023-11-03 03:40:26 24 4
gpt4 key购买 nike

我在使用 Spring Data 时遇到了很多问题和 MongoDB当涉及到索引字段时。

我已经查看了文档,但他们不太擅长解释 @Indexed(unique=true) 之间的区别。和 @Indexed(unique=false) .

我有一个我想要索引的字段,以便我可以对其执行快速查询。在这种情况下,电子邮件地址通常应该是唯一的,但 emailAddress 有可能在一段时间内为空。

但是,一旦一个记录为空 emailAddress,我就不能再有任何其他记录具有空 emailAddress。 Spring Data 拒绝使用 null 插入任何附加记录电子邮件地址。它无法抛出任何它不起作用的东西。

现在我将它设置为 unique=true ,但我正在考虑将其设置为 unique=false解决这个问题。

这会解决问题吗?

我可以通过放宽这一点来增加哪些其他问题?

MongoDB 是否允许我拥有多个相同的电子邮件地址并且仍然可以快速查询?

最佳答案

来自 mongodb 文档: http://docs.mongodb.org/manual/core/indexes/#unique-indexes

因此,如果您有唯一键,请不要将其设置为空。

老实说,在您的用例(电子邮件字段)中,我相信您不需要使用唯一 key ,您可以使用稀疏 key ,而不是,因此,没有电子邮件的文档不会占用您的 btree索引,这将节省您的空间,并提高查找速度。

关于java - Spring Data MongoDB 索引(唯一=真),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13905076/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com