1

我对 Solr 完全陌生,我正在尝试创建一个查询,该查询将返回在“成分”字段(制表符分隔的字符串)中具有一个或多个值的所有文档,但排除那些在同一个领域。我们正在运行 Solr 4.9

这里的架构:

<fields>  
<field name="_version_" type="long" indexed="true" stored="true" multiValued="false"/>
<field name="uri" type="string" indexed="true" stored="true" required="true" multiValued="false" /> 
<field name="title"  type="text_general"    indexed="true"  stored="true" multiValued="false" />
<field name="text"  type="text_general"    indexed="true"  stored="true" multiValued="false" />
<field name="ingredient"  type="tab-delimited-string"    indexed="true"  stored="true" multiValued="false" />

这里是一个文档样本:

  {
    "text": "Preheat oven to 350 degrees F.\n\nPlace potatoes, heavy cream, egg, salt, parmesan and marjoram in a blender container.\n\nCover and blend at high speed for about 30 seconds.\n\nFill dough in a greased baking dish and bake uncovered for 25-30 minutes at 350 F.\n\nPlace remaining ingredients (without the mozzarella) in a blender, cover and blend at high speed for about 10 seconds.\n\nSpread sauce on potato dough, cover with mozzarella and some sprinkles of oil and bake again uncovered for 20-25 minutes at 350 F.",
    "ingredient": "1/2 cup parmesan cheese, grind\t1 lb potato, uncooked,skin removed,diced\t1/2 cup heavy cream\t1 egg\t1 teaspoon salt\t1/2 teaspoon marjoram\t2 cloves garlic, chopped\t1 1/3 cups Tomatoes, diced\tsalt\tpepper\tbasil\t1 cup mozzarella cheese, finely grated\tolive oil",
    "uri": "http://www.food.com/recipe/potato-pizza-58181",
    "title": "Potato Pizza",
    "_version_": 1477518762807656400
  },

在搜索和阅读一些手册后,我想出了这个:

title:pizza AND ingredient:"olive oil"  AND -ingredient:("beer" "potatoes")

但它不起作用。我也试过下面的东西,但它也不起作用

title:pizza AND ingredient:"olive oil"  AND -ingredient:"beer " "potatoes"
title:pizza AND ingredient:"olive oil"  AND -ingredient:"beer" AND -ingredient:"potatoes"

我得到的结果是在成分字段中有土豆或啤酒。有什么想法吗?,我错过了什么吗?

谢谢!。

4

1 回答 1

0

我想出了这个,我只需要在我的搜索词前/附加 *。

title:pizza AND ingredient:"olive oil"  AND -ingredient:(*beer* *potatoes*)
于 2014-09-24T11:17:09.847 回答