如何使用 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 = BLUE
和 car_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))
我目前在做:
criteria = new Criteria().andOperator(where("car.color").is(car_color),
where("car_size").is(car_size))
如何使此搜索同时适用于 car_color = BLUE
和 car_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))