正则表达式regex spring 字符串匹配string-matching 大小写不敏感case-insensitive
我想在mongo不区分大小写的搜索。基本上,我想不区分大小写字符串的速配I正则表达式。这里是我的代码
Query query = new Query( Criteria.where(propName).regex(value.toString(), "i"));
但上述dosent符合我的整个字符串(字符串用空格)。它返回的值,即使它的一个子串。 例如:假设我收藏有2个值“条例”和“条例草案”法案“即使我的搜索”法案,它返回的结果,即使有,我搜索的字符串的一个子字符串 我试过Query query = new Query( Criteria.where(propName).is(value.toString()));不过上面是区分大小写的。能帮帮这一点。
本文地址 :CodeGo.net/10250490/
-------------------------------------------------------------------------------------------------------------------------
1.正则表达式/ ^账单$ /我将在不区分大小写的匹配方式只针对“条例”。 下面是一个例子,说明这个(mongoshell):
> db.foo.insert({name: "Bill"});
> db.foo.insert({name: "Bill status"});
> db.foo.insert({name: "another Bill"});
> db.foo.find()
{ "_id" : ObjectId("5018e182a499db774b92bf25"), "name" : "Bill" }
{ "_id" : ObjectId("5018e191a499db774b92bf26"), "name" : "Bill status" }
{ "_id" : ObjectId("5018e19ba499db774b92bf27"), "name" : "another Bill" }
> db.foo.find({name: /bill/i})
{ "_id" : ObjectId("5018e182a499db774b92bf25"), "name" : "Bill" }
{ "_id" : ObjectId("5018e191a499db774b92bf26"), "name" : "Bill status" }
{ "_id" : ObjectId("5018e19ba499db774b92bf27"), "name" : "another Bill" }
> db.foo.find({name: /^bill$/i})
{ "_id" : ObjectId("5018e182a499db774b92bf25"), "name" : "Bill" }
然而,一个正则表达式查询将一个索引,但如果是左根(格式为/ ^前缀/ IE的),如果第i不区分大小写的标志是你将付出巨大的性能损失的查询索引。因此,根据情况,更好的选择可能是在这样的应用程序逻辑 CodeGo.net,例如: 强制执行的情况下,当你插入项目到数据库中(例如转换“法案”,以“条例”)。 这样做对你的已知情况下的搜索(如搜索只是对“条例”)。
本文标题 :SpringMongo不区分大小写的正则表达式
本文地址 :CodeGo.net/10250490/
用python实现
name = '^%s$' % name
re_name = re.compile(name, re.IGNORECASE)
record = db.foo.find({'name':re_name});