Skip to content

Commit

Permalink
[DOCS] Reformat has_parent query docs (elastic#44443)
Browse files Browse the repository at this point in the history
  • Loading branch information
jrodewig authored Jul 19, 2019
1 parent a6b12b5 commit f3ddd36
Showing 1 changed file with 91 additions and 55 deletions.
146 changes: 91 additions & 55 deletions docs/reference/query-dsl/has-parent-query.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -4,93 +4,129 @@
<titleabbrev>Has parent</titleabbrev>
++++

The `has_parent` query accepts a query and a parent type. The query is
executed in the parent document space, which is specified by the parent
type. This query returns child documents which associated parents have
matched. For the rest `has_parent` query has the same options and works
in the same manner as the `has_child` query.
Returns child documents whose <<parent-join,joined>> parent document matches a
provided query. You can create parent-child relationships between documents in
the same index using a <<parent-join,join>> field mapping.

[WARNING]
====
Because it performs a join, the `has_parent` query is slow compared to other queries.
Its performance degrades as the number of matching parent documents increases.
Each `has_parent` query in a search can increase query time significantly.
====

[[has-parent-query-ex-request]]
==== Example request

[[has-parent-index-setup]]
===== Index setup
To use the `has_parent` query, your index must include a <<parent-join,join>>
field mapping. For example:

[source,js]
--------------------------------------------------
GET /_search
----
PUT /my-index
{
"query": {
"has_parent" : {
"parent_type" : "blog",
"query" : {
"term" : {
"tag" : "something"
"mappings": {
"properties" : {
"my-join-field" : {
"type" : "join",
"relations": {
"parent": "child"
}
},
"tag" : {
"type" : "keyword"
}
}
}
}
--------------------------------------------------
// CONSOLE
Note that the `has_parent` is a slow query compared to other queries in the
query dsl due to the fact that it performs a join. The performance degrades
as the number of matching parent documents increases. If you care about query
performance you should not use this query. However if you do happen to use
this query then use it as less as possible. Each `has_parent` query that gets
added to a search request can increase query time significantly.

[float]
==== Scoring capabilities
----
// CONSOLE
// TESTSETUP

The `has_parent` also has scoring support. The default is `false` which
ignores the score from the parent document. The score is in this
case equal to the boost on the `has_parent` query (Defaults to 1). If
the score is set to `true`, then the score of the matching parent
document is aggregated into the child documents belonging to the
matching parent document. The score mode can be specified with the
`score` field inside the `has_parent` query:
[[has-parent-query-ex-query]]
===== Example query

[source,js]
--------------------------------------------------
GET /_search
----
GET /my-index/_search
{
"query": {
"has_parent" : {
"parent_type" : "blog",
"score" : true,
"parent_type" : "parent",
"query" : {
"term" : {
"tag" : "something"
"tag" : {
"value" : "Elasticsearch"
}
}
}
}
}
}
--------------------------------------------------
----
// CONSOLE

[float]
==== Ignore Unmapped
[[has-parent-top-level-params]]
==== Top-level parameters for `has_parent`

`parent_type`::
(Required, string) Name of the parent relationship mapped for the
<<parent-join,join>> field.

`query`::
(Required, query object) Query you wish to run on parent documents of the
`parent_type` field. If a parent document matches the search, the query returns
its child documents.

`score`::
+
--
(Optional, boolean) Indicates whether the <<query-filter-context,relevance
score>> of a matching parent document is aggregated into its child documents.
Defaults to `false`.

When set to `true` the `ignore_unmapped` option will ignore an unmapped `type`
and will not match any documents for this query. This can be useful when
querying multiple indexes which might have different mappings. When set to
`false` (the default value) the query will throw an exception if the `type`
is not mapped.
If `false`, {es} ignores the relevance score of the parent document. {es} also
assigns each child document a relevance score equal to the `query`'s `boost`,
which defaults to `1`.

[float]
==== Sorting
If `true`, the relevance score of the matching parent document is aggregated
into its child documents' relevance scores.
--

Child documents can't be sorted by fields in matching parent documents via the
regular sort options. If you need to sort child documents by field in the parent
documents then you should use the `function_score` query and then just sort
by `_score`.
`ignore_unmapped`::
+
--
(Optional, boolean) Indicates whether to ignore an unmapped `parent_type` and
not return any documents instead of an error. Defaults to `false`.

Sorting tags by parent document' `view_count` field:
If `false`, {es} returns an error if the `parent_type` is unmapped.

You can use this parameter to query multiple indices that may not contain the
`parent_type`.
--

[[has-parent-query-notes]]
==== Notes

[[has-parent-query-performance]]
===== Sorting
You cannot sort the results of a `has_parent` query using standard
<<search-request-sort,sort options>>.

If you need to sort returned documents by a field in their parent documents, use
a `function_score` query and sort by `_score`. For example, the following query
sorts returned documents by the `view_count` field of their parent documents.

[source,js]
--------------------------------------------------
----
GET /_search
{
"query": {
"has_parent" : {
"parent_type" : "blog",
"parent_type" : "parent",
"score" : true,
"query" : {
"function_score" : {
Expand All @@ -102,5 +138,5 @@ GET /_search
}
}
}
--------------------------------------------------
// CONSOLE
----
// CONSOLE

0 comments on commit f3ddd36

Please sign in to comment.