solr多core查询后再join

方便自己查阅,记录于2019年8月20号。
关于solr 的多core查询,网上有很多,自己用到的也就下面这些。
项目需求,两张同样的表
如:
表1

idname
1张三

表2

idname
2张四

表3

idname_id
11
12

通常来说sql语句是这样的:

select * from (
select * from 表1
union
select * from 表2) aa name_id in( select id from 表3)
solr 对应的语句是这样的

    public static void queryMultiCore()throws Exception{
        //查询a和b下面的数据,
        HttpSolrClient sc = new HttpSolrClient("http://localhost:9090/standard");
        String shards = "http://localhost:9090/standard,http://localhost:9090/fomaforumts";
        ModifiableSolrParams solrParams = new ModifiableSolrParams();
        solrParams.set("shards", shards);//设置shard
        solrParams.set("q", "*:*");
        //in:solr(1 3) 范围:[1 TO 3]
        solrParams.set("fq", "{!join fromIndex=standard_system to=bznum from=bznum}id:[1 TO 3]");
        QueryResponse rsp = sc.query(solrParams);
        System.out.println("命中数量:"+rsp.getResults().getNumFound());
        for(SolrDocument sd:rsp.getResults()){
            System.out.println(sd);
        }
        sc.close();
    }

其中要特别注意solr在join时候,关于条件的写法:sql中的in()对应的是{!join fromIndex=standard_system to=bznum from=bznum}id:(1 3); solr表示范围的是{!join fromIndex=standard_system to=bznum from=bznum}id:[1 TO 3],这个是我在网上查了半天终于找到的。
这里要感谢这位大神:https://www.jianshu.com/p/67c42c20ce6f

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值