您的位置:首页 > 数据库 > Mongodb

python 实现 mongodb 不区分大小写查询

2017-02-23 15:22 337 查看
SpringMongo不区分大小写的正则表达式 

正则表达式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});
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  正则表达式 mongodb