zoukankan      html  css  js  c++  java
  • MongoDB 正则表达式

    示例

    MongoDB 使用 $regex 操作符来设置匹配字符串的正则表达式。

    > db.col.find()
    { "_id" : ObjectId("56c6bbef64799370c0ef358a"), "x" : "hello world", "tags" : [ "a", "b" ] }
    { "_id" : ObjectId("56c6bbfe64799370c0ef358b"), "x" : "hi world", "tags" : [ "b" ] }
    { "_id" : ObjectId("56c6bc9e64799370c0ef358c"), "x" : "nothing" }
    > db.col.find({x:/world/}) { "_id" : ObjectId("56c6bbfe64799370c0ef358b"), "x" : "hi world", "tags" : [ "b" ] } { "_id" : ObjectId("56c6bbef64799370c0ef358a"), "x" : "hello world", "tags" : [ "a", "b" ] }
    > db.col.find({x:{$regex:"world"}}) { "_id" : ObjectId("56c6bbfe64799370c0ef358b"), "x" : "hi world", "tags" : [ "b" ] } { "_id" : ObjectId("56c6bbef64799370c0ef358a"), "x" : "hello world", "tags" : [ "a", "b" ] }

    上面后两种操作是等价的。

    不区分大小写

    > db.col.find({x:{$regex:"world", $options:"$i"}})
    { "_id" : ObjectId("56c6bd9964799370c0ef358d"), "x" : "hihi WORLD" }
    { "_id" : ObjectId("56c6bbfe64799370c0ef358b"), "x" : "hi world", "tags" : [ "b" ] }
    { "_id" : ObjectId("56c6bbef64799370c0ef358a"), "x" : "hello world", "tags" : [ "a", "b" ] }

    or

    > db.col.find({x:/world/i})
    { "_id" : ObjectId("56c6bd9964799370c0ef358d"), "x" : "hihi WORLD" }
    { "_id" : ObjectId("56c6bbfe64799370c0ef358b"), "x" : "hi world", "tags" : [ "b" ] }
    { "_id" : ObjectId("56c6bbef64799370c0ef358a"), "x" : "hello world", "tags" : [ "a", "b" ] }

    数组使用正则表达式

    > db.col.find({tags:/b/})
    { "_id" : ObjectId("56c6bbef64799370c0ef358a"), "x" : "hello world", "tags" : [ "a", "b" ] }
    { "_id" : ObjectId("56c6bbfe64799370c0ef358b"), "x" : "hi world", "tags" : [ "b" ] }
    { "_id" : ObjectId("56c6bedf64799370c0ef358e"), "tags" : [ "abc", "m" ] }

    可见数组中包含字符‘b’的都找出来了(包括“abc”)。

    正则中包含变量

    需要用eval将组合的字符串进行转换

    > v="world"
    world
    
    > db.col.find({x:eval("/" + v + "/i")})
    { "_id" : ObjectId("56c6bd9964799370c0ef358d"), "x" : "hihi WORLD" }
    { "_id" : ObjectId("56c6bbfe64799370c0ef358b"), "x" : "hi world", "tags" : [ "b" ] }
    { "_id" : ObjectId("56c6bbef64799370c0ef358a"), "x" : "hello world", "tags" : [ "a", "b" ] }
  • 相关阅读:
    javascript大神修炼记(5)——OOP思想(封装)
    javascript大神修炼记(4)——循环
    javascript大神修炼记(3)——条件分支
    javascript大神修炼记(2)——运算符
    javascript大神修炼记(1)——入门介绍
    07 PB12.5版本的WEBSERVICE部署指南
    06 DW.NET在C#中应用的特殊注意事项
    分享一款html5实现图片生成多种尺寸手机封面
    cordova打包时执行到:processArmv7DebugResources时报错
    Video标签的playsinline属性
  • 原文地址:https://www.cnblogs.com/kaituorensheng/p/5201225.html
Copyright © 2011-2022 走看看