如何使用 Criteria、MongoTemplate 和 Java 搜索不区分大小写的值?

How search case insensitive values using Criteria, MongoTemplate and Java?

我目前在做:

criteria = new Criteria().andOperator(where("car.color").is(car_color),
                                      where("car_size").is(car_size))

如何使此搜索同时适用于 car_color = BLUEcar_color = blue


更新:

部分有效:

where("car.color").regex(car_color, "i"),

但是下面的所有值都会更新:

BLUE
BBLUE
blue
bluee

我只想更新 car_color 变量中匹配的内容(不区分大小写)。

我认为您想要的是将字符串预处理为全部大写或全部小写。在 java 中,这样做是这样的:

car_color.toLowerCase() 要么 car_color.toUpperCase()

那你就知道是全大写还是全小写了,可以适当的比较字符串

我的问题的解决方案是:

criteria = new Criteria().andOperator(where("car.color").regex("^" + car_color+ "$", "i"),
                                      where("car_size").is(car_size))