草庐IT

mongodb - 如何在不提及字段名称的情况下在mongodb中搜索记录?

coder 2023-11-04 原文

我正在 mongodb 中搜索满足我的搜索条件的查询。我在数据库集合中有一条记录:

{
 "_id": ObjectId("5b3d970398e9d099427896c3"),
 "role": "New Booking is there by abc",
 "date": "07/04/2018",
 "idaddress": "213.123.123.213",
 "booking": {
   "bedroom": 4,
   "bathroom": 6,
   "customer": "abc",
   "email": "abc@gmail.com",
   "provider": "provider1",
   "address": "brazil",
   "appt": "123456",
   "phone": "987654321"
 }
}

在此记录中,booking 对象有 8 个字段,为了进行搜索,我正在使用查询:

db.collection_name.find({ "booking.field_name" : {$regex : /data$/}})

要从每个字段(客户、电子邮件、提供商、地址、应用程序、电话)中搜索匹配的值,我必须在同一行中写上字段名称,但是如果我在预订对象下有 100 个字段,那么我需要每个字段名称在同一行中写 100 次。 我正在寻找从每个字段搜索的查询,为此我尝试了 $text 子句,例如: bson.M{"_id": bson.M{'$type': "objectId"} } 但是 $text 子句只会搜索完整的单词而不是正则表达式(词干词)单词示例:- "This is a string" 在这一行中我想搜索 "str" word 但它不会显示与之匹配的记录。

有人会为此建议任何示例吗?这会占用我很多时间。

帮我解决了这个问题谢谢。

最佳答案

聚合框架就是这种方式。正如@Prajval 所说,您有一个对象,因此解决方案是在查询之前将其转换为数组。这是代码:

db.test1.aggregate(
    [
        {
            $project: {
                role:1,
                date:1,
                idadress:1,
                booking_values:{$objectToArray:"$booking"}
            }
        },
    ]
);

这将输出

{ 
    "_id" : ObjectId("5b3d970398e9d099427896c3"), 
    "role" : "New Booking is there by abc", 
    "date" : "07/04/2018", 
    "booking_values" : [
        {
            "k" : "bedroom", 
            "v" : NumberInt(4)
        }, 
        {
            "k" : "bathroom", 
            "v" : NumberInt(6)
        }, 
        {
            "k" : "customer", 
            "v" : "abc"
        }, 
        {
            "k" : "email", 
            "v" : "abc@gmail.com"
        }, 
        {
            "k" : "provider", 
            "v" : "provider1"
        }, 
        {
            "k" : "address", 
            "v" : "brazil"
        }, 
        {
            "k" : "appt", 
            "v" : "123456"
        }, 
        {
            "k" : "phone", 
            "v" : "987654321"
        }
    ]
}

从这里您可以轻松添加聚合阶段以获得您需要的准确结果。 (整个文档或仅匹配标准的预订值,预订字段名称 (k) 的标准,预订字段值 (v) 或两者等...)

如果您需要帮助来实现这一目标,只需提供您的预期结果即可。

关于mongodb - 如何在不提及字段名称的情况下在mongodb中搜索记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51205142/

有关mongodb - 如何在不提及字段名称的情况下在mongodb中搜索记录?的更多相关文章

  1. ruby - 如何在 Ruby 中顺序创建 PI - 2

    出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits

  2. ruby - 如何在 buildr 项目中使用 Ruby 代码? - 2

    如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby​​

  3. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  4. ruby-on-rails - 如何在 ruby​​ 中使用两个参数异步运行 exe? - 2

    exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby​​中使用两个参数异步运行exe吗?我已经尝试过ruby​​命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何ruby​​gems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除

  5. ruby - 默认情况下使选项为 false - 2

    这是在Ruby中设置默认值的常用方法:classQuietByDefaultdefinitialize(opts={})@verbose=opts[:verbose]endend这是一个容易落入的陷阱:classVerboseNoMatterWhatdefinitialize(opts={})@verbose=opts[:verbose]||trueendend正确的做法是:classVerboseByDefaultdefinitialize(opts={})@verbose=opts.include?(:verbose)?opts[:verbose]:trueendend编写Verb

  6. ruby - 如何在续集中重新加载表模式? - 2

    鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende

  7. ruby-on-rails - 如何验证非模型(甚至非对象)字段 - 2

    我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss

  8. ruby-on-rails - form_for 中不在模型中的自定义字段 - 2

    我想向我的Controller传递一个参数,它是一个简单的复选框,但我不知道如何在模型的form_for中引入它,这是我的观点:{:id=>'go_finance'}do|f|%>Transferirde:para:Entrada:"input",:placeholder=>"Quantofoiganho?"%>Saída:"output",:placeholder=>"Quantofoigasto?"%>Nota:我想做一个额外的复选框,但我该怎么做,模型中没有一个对象,而是一个要检查的对象,以便在Controller中创建一个ifelse,如果没有检查,请帮助我,非常感谢,谢谢

  9. ruby - 如何在 Ruby 中拆分参数字符串 Bash 样式? - 2

    我正在为一个项目制作一个简单的shell,我希望像在Bash中一样解析参数字符串。foobar"helloworld"fooz应该变成:["foo","bar","helloworld","fooz"]等等。到目前为止,我一直在使用CSV::parse_line,将列分隔符设置为""和.compact输出。问题是我现在必须选择是要支持单引号还是双引号。CSV不支持超过一个分隔符。Python有一个名为shlex的模块:>>>shlex.split("Test'helloworld'foo")['Test','helloworld','foo']>>>shlex.split('Test"

  10. ruby - 在没有 sass 引擎的情况下使用 sass 颜色函数 - 2

    我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re

随机推荐