Has child query

Has child query

Returns parent documents whose joined child documents match a provided query. You can create parent-child relationships between documents in the same index using a join field mapping.

Because it performs a join, the has_child is slow compared to other queries. Its performance degrades as the number of matching child documents pointing to unique parent documents increases. Each has_child query in a search can increase query time significantly.

If you care about query performance, do not use this query. If you need to use the has_child query, use it as rarely as possible.

Example request

Index setup

To use the has_child query, your index must include a join field mapping. For example:

  1. resp = client.indices.create(
  2. index="my-index-000001",
  3. mappings={
  4. "properties": {
  5. "my-join-field": {
  6. "type": "join",
  7. "relations": {
  8. "parent": "child"
  9. }
  10. }
  11. }
  12. },
  13. )
  14. print(resp)
  1. response = client.indices.create(
  2. index: 'my-index-000001',
  3. body: {
  4. mappings: {
  5. properties: {
  6. "my-join-field": {
  7. type: 'join',
  8. relations: {
  9. parent: 'child'
  10. }
  11. }
  12. }
  13. }
  14. }
  15. )
  16. puts response
  1. const response = await client.indices.create({
  2. index: "my-index-000001",
  3. mappings: {
  4. properties: {
  5. "my-join-field": {
  6. type: "join",
  7. relations: {
  8. parent: "child",
  9. },
  10. },
  11. },
  12. },
  13. });
  14. console.log(response);
  1. PUT /my-index-000001
  2. {
  3. "mappings": {
  4. "properties": {
  5. "my-join-field": {
  6. "type": "join",
  7. "relations": {
  8. "parent": "child"
  9. }
  10. }
  11. }
  12. }
  13. }

Example query

  1. resp = client.search(
  2. query={
  3. "has_child": {
  4. "type": "child",
  5. "query": {
  6. "match_all": {}
  7. },
  8. "max_children": 10,
  9. "min_children": 2,
  10. "score_mode": "min"
  11. }
  12. },
  13. )
  14. print(resp)
  1. const response = await client.search({
  2. query: {
  3. has_child: {
  4. type: "child",
  5. query: {
  6. match_all: {},
  7. },
  8. max_children: 10,
  9. min_children: 2,
  10. score_mode: "min",
  11. },
  12. },
  13. });
  14. console.log(response);
  1. GET /_search
  2. {
  3. "query": {
  4. "has_child": {
  5. "type": "child",
  6. "query": {
  7. "match_all": {}
  8. },
  9. "max_children": 10,
  10. "min_children": 2,
  11. "score_mode": "min"
  12. }
  13. }
  14. }

Top-level parameters for has_child

type

(Required, string) Name of the child relationship mapped for the join field.

query

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

ignore_unmapped

(Optional, Boolean) Indicates whether to ignore an unmapped type and not return any documents instead of an error. Defaults to false.

If false, Elasticsearch returns an error if the type is unmapped.

You can use this parameter to query multiple indices that may not contain the type.

max_children

(Optional, integer) Maximum number of child documents that match the query allowed for a returned parent document. If the parent document exceeds this limit, it is excluded from the search results.

min_children

(Optional, integer) Minimum number of child documents that match the query required to match the query for a returned parent document. If the parent document does not meet this limit, it is excluded from the search results.

score_mode

(Optional, string) Indicates how scores for matching child documents affect the root parent document’s relevance score. Valid values are:

  • none (Default)

    Do not use the relevance scores of matching child documents. The query assigns parent documents a score of 0.

    avg

    Use the mean relevance score of all matching child documents.

    max

    Uses the highest relevance score of all matching child documents.

    min

    Uses the lowest relevance score of all matching child documents.

    sum

    Add together the relevance scores of all matching child documents.

Notes

Sorting

You cannot sort the results of a has_child query using standard sort options.

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

  1. resp = client.search(
  2. query={
  3. "has_child": {
  4. "type": "child",
  5. "query": {
  6. "function_score": {
  7. "script_score": {
  8. "script": "_score * doc['click_count'].value"
  9. }
  10. }
  11. },
  12. "score_mode": "max"
  13. }
  14. },
  15. )
  16. print(resp)
  1. const response = await client.search({
  2. query: {
  3. has_child: {
  4. type: "child",
  5. query: {
  6. function_score: {
  7. script_score: {
  8. script: "_score * doc['click_count'].value",
  9. },
  10. },
  11. },
  12. score_mode: "max",
  13. },
  14. },
  15. });
  16. console.log(response);
  1. GET /_search
  2. {
  3. "query": {
  4. "has_child": {
  5. "type": "child",
  6. "query": {
  7. "function_score": {
  8. "script_score": {
  9. "script": "_score * doc['click_count'].value"
  10. }
  11. }
  12. },
  13. "score_mode": "max"
  14. }
  15. }
  16. }