Script query

Script query

Runtime fields provide a very similar feature that is more flexible. You write a script to create field values and they are available everywhere, such as fields, all queries, and aggregations.

Filters documents based on a provided script. The script query is typically used in a filter context.

Using scripts can result in slower search speeds. See Scripts, caching, and search speed.

Example request

  1. resp = client.search(
  2. query={
  3. "bool": {
  4. "filter": {
  5. "script": {
  6. "script": "\n double amount = doc['amount'].value;\n if (doc['type'].value == 'expense') {\n amount *= -1;\n }\n return amount < 10;\n "
  7. }
  8. }
  9. }
  10. },
  11. )
  12. print(resp)
  1. response = client.search(
  2. body: {
  3. query: {
  4. bool: {
  5. filter: {
  6. script: {
  7. script: "\n double amount = doc['amount'].value;\n if (doc['type'].value == 'expense') {\n amount *= -1;\n }\n return amount < 10;\n "
  8. }
  9. }
  10. }
  11. }
  12. }
  13. )
  14. puts response
  1. const response = await client.search({
  2. query: {
  3. bool: {
  4. filter: {
  5. script: {
  6. script:
  7. "\n double amount = doc['amount'].value;\n if (doc['type'].value == 'expense') {\n amount *= -1;\n }\n return amount < 10;\n ",
  8. },
  9. },
  10. },
  11. },
  12. });
  13. console.log(response);
  1. GET /_search
  2. {
  3. "query": {
  4. "bool": {
  5. "filter": {
  6. "script": {
  7. "script": """
  8. double amount = doc['amount'].value;
  9. if (doc['type'].value == 'expense') {
  10. amount *= -1;
  11. }
  12. return amount < 10;
  13. """
  14. }
  15. }
  16. }
  17. }
  18. }

You can achieve the same results in a search query by using runtime fields. Use the fields parameter on the _search API to fetch values as part of the same query:

  1. resp = client.search(
  2. runtime_mappings={
  3. "amount.signed": {
  4. "type": "double",
  5. "script": "\n double amount = doc['amount'].value;\n if (doc['type'].value == 'expense') {\n amount *= -1;\n }\n emit(amount);\n "
  6. }
  7. },
  8. query={
  9. "bool": {
  10. "filter": {
  11. "range": {
  12. "amount.signed": {
  13. "lt": 10
  14. }
  15. }
  16. }
  17. }
  18. },
  19. fields=[
  20. {
  21. "field": "amount.signed"
  22. }
  23. ],
  24. )
  25. print(resp)
  1. response = client.search(
  2. body: {
  3. runtime_mappings: {
  4. 'amount.signed' => {
  5. type: 'double',
  6. script: "\n double amount = doc['amount'].value;\n if (doc['type'].value == 'expense') {\n amount *= -1;\n }\n emit(amount);\n "
  7. }
  8. },
  9. query: {
  10. bool: {
  11. filter: {
  12. range: {
  13. 'amount.signed' => {
  14. lt: 10
  15. }
  16. }
  17. }
  18. }
  19. },
  20. fields: [
  21. {
  22. field: 'amount.signed'
  23. }
  24. ]
  25. }
  26. )
  27. puts response
  1. const response = await client.search({
  2. runtime_mappings: {
  3. "amount.signed": {
  4. type: "double",
  5. script:
  6. "\n double amount = doc['amount'].value;\n if (doc['type'].value == 'expense') {\n amount *= -1;\n }\n emit(amount);\n ",
  7. },
  8. },
  9. query: {
  10. bool: {
  11. filter: {
  12. range: {
  13. "amount.signed": {
  14. lt: 10,
  15. },
  16. },
  17. },
  18. },
  19. },
  20. fields: [
  21. {
  22. field: "amount.signed",
  23. },
  24. ],
  25. });
  26. console.log(response);
  1. GET /_search
  2. {
  3. "runtime_mappings": {
  4. "amount.signed": {
  5. "type": "double",
  6. "script": """
  7. double amount = doc['amount'].value;
  8. if (doc['type'].value == 'expense') {
  9. amount *= -1;
  10. }
  11. emit(amount);
  12. """
  13. }
  14. },
  15. "query": {
  16. "bool": {
  17. "filter": {
  18. "range": {
  19. "amount.signed": { "lt": 10 }
  20. }
  21. }
  22. }
  23. },
  24. "fields": [{"field": "amount.signed"}]
  25. }

Top-level parameters for script

script

(Required, script object) Contains a script to run as a query. This script must return a boolean value, true or false.

Notes

Custom Parameters

Like filters, scripts are cached for faster execution. If you frequently change the arguments of a script, we recommend you store them in the script’s params parameter. For example:

  1. resp = client.search(
  2. query={
  3. "bool": {
  4. "filter": {
  5. "script": {
  6. "script": {
  7. "source": "doc['num1'].value > params.param1",
  8. "lang": "painless",
  9. "params": {
  10. "param1": 5
  11. }
  12. }
  13. }
  14. }
  15. }
  16. },
  17. )
  18. print(resp)
  1. response = client.search(
  2. body: {
  3. query: {
  4. bool: {
  5. filter: {
  6. script: {
  7. script: {
  8. source: "doc['num1'].value > params.param1",
  9. lang: 'painless',
  10. params: {
  11. "param1": 5
  12. }
  13. }
  14. }
  15. }
  16. }
  17. }
  18. }
  19. )
  20. puts response
  1. const response = await client.search({
  2. query: {
  3. bool: {
  4. filter: {
  5. script: {
  6. script: {
  7. source: "doc['num1'].value > params.param1",
  8. lang: "painless",
  9. params: {
  10. param1: 5,
  11. },
  12. },
  13. },
  14. },
  15. },
  16. },
  17. });
  18. console.log(response);
  1. GET /_search
  2. {
  3. "query": {
  4. "bool": {
  5. "filter": {
  6. "script": {
  7. "script": {
  8. "source": "doc['num1'].value > params.param1",
  9. "lang": "painless",
  10. "params": {
  11. "param1": 5
  12. }
  13. }
  14. }
  15. }
  16. }
  17. }
  18. }

Allow expensive queries

Script queries will not be executed if search.allow_expensive_queries is set to false.