草庐IT

regex_extract

全部标签

regex - Mongoose 验证 : required : false, 验证 : regex, 问题与空值

我从Mongoose验证中得到这条消息:'Validatorfailedforpathphonewithvalue``'这不应该发生,因为不需要电话。这是我的模型架构:varuser=newSchema({_id:{type:String,required:true},name:{type:String,required:true},phone:{type:String,required:false,validate:/^\d{10}$/},password:{type:String},added:{type:Date,default:Date.now},},{collection:'

regex - 具有多个选项的 MongoDB 正则表达式

如何使用具有多个选项的正则表达式在mongo中进行搜索?根据mongodocumentation我可以,db.collection.find({field:{$regex:'acme.*corp',$options:'i'}})如何使用多个选项(例如,i和m)执行此操作?喜欢$options:'im'?或者$options:['i','m']? 最佳答案 正确的语法是这样的(最有可能是基于下面列出的我的观察):$options:'im'列表regexoptions有说明数据:db.a.insert({"a":"helloSam"})

regex - MongoDB 反向正则表达式

我在MongoDB中有一个带有正则表达式属性的文档{_id:ObjectId("516023189732da20ce000004"),regex:/^(my|your)\s+regex$/}我需要用db.col.find({regex:'yourregex'})和db.col.find({regex:'my正则表达式'})。在MySQL中,我会这样做:SELECT*FROMtableWHERE'myregex'REGEXPtable.regex。我如何在MongoDB中实现这一点? 最佳答案 您可以按以下方式使用$where运算符:

mongodb - 将地理数据导入 Mongodb 时出错 : Can't extract geo keys from object, 畸形几何

我正在尝试将一些地理数据(超过40K)导入mongodb(3),但有时我会遇到一些文档的错误:"code":16755,"errmsg":"insertDocument::causedby::16755Can'textractgeokeysfromobject,malformedgeometryIhavecheckedthedocumentandit'savalidgeojson,respectingmongodbformat[long,lat].AndwhenIinsertthedocumentwithoutthepolygon,itworks...Icannotfigureoutw

regex - 与 mongodb 聚合中的子字符串匹配

在我的mongodb集合中,我有一个time_stamp="2013-06-3023:58:37928"。我需要将“$match”与日期一起使用,例如time_stamp="2013-06-30"。那么我怎样才能得到这样的子字符串呢?以前我试过$substr,但它显示错误"errmsg":"exception:invalidoperator:$substr" 最佳答案 自从您尝试了$match以来,我认为您正在尝试使用聚合框架进行查询&$substr运营商。我创建了一个简单的示例来展示如何使用$substr在聚合框架上实现您想要的结

regex - Spring Mongo 不区分大小写的搜索正则表达式

我正在尝试在Mongo中进行不区分大小写的搜索。基本上我想要不区分大小写的字符串匹配我正在使用正则表达式。这是我的代码Queryquery=newQuery(Criteria.where(propName).regex(value.toString(),"i"));但是上面的dosent匹配我的整个字符串(有时带有空格的字符串)。即使它是一个子字符串,它也会返回值。例如:假设我的集合有2个值“Bill”和“Billstatus”,即使我的搜索是“billstatus”,它也会返回“bill”。即使字符串有子字符串,它也会返回结果我正在寻找我试过Queryquery=newQuery(C

regex - 无法在 mongodb 的 $in 运算符中使用正则表达式

我正在尝试将regex与文档中提到的$in运算符一起使用,但我仍然无法获取该值。db.users.find({'profile.firstName':{$in:["/justin/i"]}}).count()=0但是当我这样使用的时候db.users.find({'profile.firstName':{$in:["justin"]}}).count()=1和db.users.find({'profile.firstName':{$in:["Justin"]}}).count()=2已编辑问题这个问题好像不太清楚我会加上代码方便理解我正在尝试从不区分大小写的查询中获取文档列表。我认为最

MySQL Regex,需要以任意顺序匹配短语

我正在使用MySQL数据库来搜索类别列表。我的查询是:select*fromcatwherenameREGEXP('(region_LongIsland)+(.)*(sport_OutdoorTrack)');传入值“region_LongIsland”和“sport_OutdoorTrack”的位置。我需要能够匹配这些类别,而不管它们的顺序如何。在表格中,可以有这些类别的各种组合两类。我需要匹配同时具有这两个类别的所有记录,无论它们以何种顺序列出。我无法更改查询本身,只能修改传递给REGEXP函数的内容。谢谢 最佳答案 如果您只能

MySQL - 令人困惑的 RegEx 变量问题

我需要一些有关RegEx的帮助。这个概念很简单,但实际的解决方案远远超出了我所知道的。如果有人能解释我如何实现我想要的效果(并提供任何示例代码的解释),我将不胜感激!基本上,想象一个存储以下字符串的数据库表:'Mynameis$1.Iwonderwho$2is.'首先,请记住美元符号数字格式是一成不变的。这不仅适用于此示例——这就是这些通配符的实际存储方式。我希望像下面这样的输入能够返回上面的字符串。'MynameisJohn.IwonderwhoSarahis.'我将如何创建一个使用这种格式的通配符进行搜索的查询,然后返回适用的行?我想正则表达式是最好的方法。请记住,理论上,任何数量

C# 排序并放回 Regex.matches

是否有任何方法可以使用RegEx.Matches以不同的(字母顺序)顺序查找和写回匹配值?现在我有这样的东西:varpattern=@"(KEY`[\w]+?`\(`.*`*\))";varkeys=Regex.Matches(line,pattern);Console.WriteLine("\n\n");foreach(Matchmatchinkeys){Console.WriteLine(match.Index+"="+match.Value.Replace("\n","").Trim());}但我真正需要的是获取table.sql转储并按字母顺序对现有索引进行排序,示例代码:li