把头发拉出来...... MongoDB查询

时间:2013-03-05 15:53:34

标签: mongodb querying

简单查询不适用于我的mongodb数据库。

在控制台中我运行

db.quads.find({});

我收到了' quads'中的所有文件。集合,其中之一是:

{ "subject" : "u:http://dbpedia.org/resource/Tim_Berners-Lee", "predicate" : "u:http://dbpedia.org/ontology/abstract", "object" : "l:\"Sir Timothy John Berners-Lee KBE, OM, FRS (TimBL ou TBL) é um físico britânico, cientista da computação e professor do MIT. É o criador da World Wide Web, tendo feito a primeira proposta para sua criação em março de 1989. Em 25 de dezembro de 1990, com a ajuda de Robert Cailliau e um jovem estudante do CERN, implementou a primeira comunicação bem-sucedida entre um cliente HTTP e o servidor através da internet. Berners-Lee é o diretor do World Wide Web Consortium (W3C), que supervisiona o desenvolvimento continuado da web. Também é o fundador da Fundação World Wide Web e é um pesquisador sênior e titular e fundador da cadeira de 3Com no Laboratório de Inteligência Artificial e Ciência da Computação do MIT (CSAIL). É um diretor da The Web Science Research Initiative (WSRI) e um membro do conselho consultivo do Centro de Inteligência Coletiva do MIT. Em abril de 2009, foi eleito como membro da Academia Nacional de Ciências dos Estados Unidos, sediada em Washington, D.C. Em 2004, Timothy venceu o Millennium Technology Prize, o que lhe rendeu um milhão de euros.\"@pt", "graph" : "u:http://example.org/people", "_id" : ObjectId("5134aa893fff1d490400009c") }

人们会期望像这样运行查询......

db.quads.find({"subject" : "u:http://dbpedia.org/resource/Tim_Berners-Lee"});

...我会得到至少一个文件,因为有一个文件带有"主题"字段值为' u:http://dbpedia.org/resource/Tim_Berners-Lee'。

但我什么也没得到......我也尝试过通配符查询:

db.quads.find({"subject" : "/.*Tim_Berners-Lee.*/"});

无济于事......我做错了什么?

谢谢!

1 个答案:

答案 0 :(得分:1)

我能够使用两种方法获得预期结果:

db.quads.find({“subject”:/。* Tim_Berners-Lee。* /}); 和 db.quads.find({“subject”:“u:http://dbpedia.org/resource/Tim_Berners-Lee”});

也许你正面临一些shell windows编码问题,请按照你的说法列出所有文档,并确保输出为find命令的输入值。如果可能的话,尝试从不同的机器连接或尝试使用cygwin,如果您正在使用Windows或尝试从Linux机器连接。

此致 Moacy