I created issue https://issues.apache.org/jira/browse/SOLR-3062 for this
problem.  I was able to track it down to something in this commit -
http://svn.apache.org/viewvc?view=revision&revision=1188624 (LUCENE-1536:
Filters can now be applied down-low, if their DocIdSet implements a new
bits() method, returning all documents in a random access way
) - before that commit the join / fq functionality works as expected /
documented on the wiki page.  After that commit it's broken.

Any assistance is greatly appreciated!

Thanks,

Mike

On Thu, Jan 26, 2012 at 11:04 AM, Mike Hugo <m...@piragua.com> wrote:

> Hello,
>
> I'm trying out the Solr JOIN query functionality on trunk.  I have the
> latest checkout, revision #1236272 - I did the following steps to get the
> example up and running:
>
> cd solr
> ant example
> java -jar start.jar
> cd exampledocs
> java -jar post.jar *.xml
>
> Then I tried a few of the sample queries on the wiki page
> http://wiki.apache.org/solr/Join.  In particular, this is one that I'm
> interest in
>
> Find all manufacturer docs named "belkin", then join them against
>> (product) docs and filter that list to only products with a price less than
>> 12 dollars
>>
>> http://localhost:8983/solr/select?q={!join+from=id+to=manu_id_s}compName_s:Belkin&fq=price:%5B%2A+TO+12%5D<http://localhost:8983/solr/select?q=%7B!join+from=id+to=manu_id_s%7DcompName_s:Belkin&fq=price:%5B%2A+TO+12%5D>
>
>
> However, when I run that query, I get two results, one with a price of
> 19.95 and another with a price of 11.5  Because of the filter query, I'm
> only expecting to see one result - the one with a price of 11.99.
>
> I was also able to replicate this in a unit test added to
> org.apache.solr.TestJoin:
>
>   @Test
>   public void testJoin_withFilterQuery() throws Exception {
>     assertU(add(doc("id", "1","name", "john", "title", "Director",
> "dept_s","Engineering")));
>     assertU(add(doc("id", "2","name", "mark", "title", "VP",
> "dept_s","Marketing")));
>     assertU(add(doc("id", "3","name", "nancy", "title", "MTS",
> "dept_s","Sales")));
>     assertU(add(doc("id", "4","name", "dave", "title", "MTS",
> "dept_s","Support", "dept_s","Engineering")));
>     assertU(add(doc("id", "5","name", "tina", "title", "VP",
> "dept_s","Engineering")));
>
>     assertU(add(doc("id","10", "dept_id_s", "Engineering", "text","These
> guys develop stuff")));
>     assertU(add(doc("id","11", "dept_id_s", "Marketing", "text","These
> guys make you look good")));
>     assertU(add(doc("id","12", "dept_id_s", "Sales", "text","These guys
> sell stuff")));
>     assertU(add(doc("id","13", "dept_id_s", "Support", "text","These guys
> help customers")));
>
>     assertU(commit());
>
>     //***********
>     //This works as expected - the correct number of results are found
>     //***********
>     // find people that develop stuff
>     assertJQ(req("q","{!join from=dept_id_s to=dept_s}text:develop",
> "fl","id")
>
> ,"/response=={'numFound':3,'start':0,'docs':[{'id':'1'},{'id':'4'},{'id':'5'}]}"
>     );
>
> *    //************
> *    // this fails - the response returned finds all three people - it
> should only find John*
> *    //    expected
> =/response=={"numFound":1,"start":0,"docs":[{"id":"1"}]}*
> *    //    response = {*
> *    //        "responseHeader":{*
> *    //      "status":0,*
> *    //          "QTime":4},*
> *    //    "response":{"numFound":3,"start":0,"docs":[*
> *    //      {*
> *    //        "id":"1"},*
> *    //      {*
> *    //        "id":"4"},*
> *    //      {*
> *    //        "id":"5"}]*
> *    //    }}*
> *    //************
> *    // find people that develop stuff - but limit via filter query to a
> name of "john"*
> *    assertJQ(req("q","{!join from=dept_id_s to=dept_s}text:develop",
> "fl","id", "fq", "name:john")*
> *        ,"/response=={'numFound':1,'start':0,'docs':[{'id':'1'}]}"*
> *    );*
>
>   }
>
>
> Interestingly, I know this worked at some point.  I had a snapshot build
> in my ivy cache from 10/2/2011 and it was working with that
> build maven_artifacts/org/apache/solr/
> solr/4.0-SNAPSHOT/solr-4.0-20111002.161157-1.pom"
>
>
> Mike
>

Reply via email to