6

我试图对 CSV 进行 mongoexport,但只选择带有查询的某些记录。这是我的命令(Windows 7 cmd):

mongoexport --host foo.com --port 27017 --username bar -p --db foo --csv --fields col1,col2,col3 --collection bar --out dump_q.csv --query '{"recent":"yes"}'

但是输入密码后,我得到一个错误:

assertion: 16619 code FailedToParse: FailedToParse: Expecting '{': offset:0

该命令在没有查询参数的情况下工作正常,但我无法弄清楚查询有什么问题:

--query '{"recent":"yes"}'

非常感谢任何帮助


答案摘要:

  1. 确保使用双引号括住查询并使用单引号括住字符串,例如

    --query "{'recent':'yes'}"

  2. 还要确保您的查询中没有空格,否则命令提示符会将其解析为另一个参数。所以没有

    --query "{'recent': 'yes'}" (注意中间的空格)

  3. 包含嵌套字段的查询不起作用,例如:

    --query "{'folder.recent':'yes'}"

4

2 回答 2

5

您需要使用双引号来包含查询字符串(以及单引号或两个引号以在字符串内转义)

--query "{'recent':'yes'}"

完全的:

mongoexport --host foo.com --port 27017 --username bar -p
        --db foo --csv --fields col1,col2,col3 
        --collection bar --out dump_q.csv --query "{'recent':'yes'}"
于 2014-01-30T13:20:35.310 回答
0

来自mongoexport 文档

--查询,-q

Provides a JSON document as a query that optionally limits the documents returned in the export.

您的查询字符串似乎格式正确。你甚至可以省略最近的双引号。

单引号或双引号似乎无关紧要,只要您坚持在外部和内部使用不同的类型即可。

你确定这是一个有效的查询吗?如果在数据库中运行以下命令,输出是什么?那么find()呢?

db.bar.count({"recent":"yes"})
于 2014-01-30T12:54:10.957 回答