十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章主要讲解了“怎么使用java solr嵌套文档”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用java solr嵌套文档”吧!
创新互联建站是一家集网站建设,固阳企业网站建设,固阳品牌网站建设,网站定制,固阳网站建设报价,网络营销,网络优化,固阳网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
创建嵌套文档
"id": "A", "queryGroup": "group1", "_childDocuments_": [ { "metricScore": "0.86", "metric": "p", "docType": "child", "id": 12894 }, { "metricScore": "0.62", "metric": "r", "docType": "child", "id": 12895 } ], "docType": "parent",
父文档和子文档都需要唯一标识符(上文中的id),并且需要唯一。
创建实体
public class Parent { @Field private String id; ... @Field(child = true) private Listchildren; }
插入solr
Parent sampleParent = new Parent(); Child sampleChild = new Child(); //you need to implement it in your POJO sampleParent.addChildDocument(sampleChild); solr.addBean("collection", sampleParent)
通过子文档的内容查询父文档
q={!parent which=} e.g. q={!parent which=docType:"parent"}title:(child title terms)
但是这样返回结果会返回所有父文档,如果要过滤掉没有子文档的集合则增加如下筛选
fl=*,[child parentFilter=doc_type:parent childFilter=id:*]
通常实际工作中子文档需要更复杂的筛选条件
fl=*,[child parentFilter=doc_type:book childFilter=$childQuery limit=100]&childQuery=(id:(12894 OR 12895))
fl=*,[child parentFilter=doc_type:book childFilter=$childQuery limit=100]&childQuery=(id:12894 OR id:12895)
感谢各位的阅读,以上就是“怎么使用java solr嵌套文档”的内容了,经过本文的学习后,相信大家对怎么使用java solr嵌套文档这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!