[[painless-sort-context]] === Sort context Use a Painless script to {ref}/sort-search-results.html[sort] the documents in a query. *Variables* `params` (`Map`, read-only):: User-defined parameters passed in as part of the query. `doc` (`Map`, read-only):: Contains the fields of the current document. For single-valued fields, the value can be accessed via `doc['fieldname'].value`. For multi-valued fields, this returns the first value; other values can be accessed via `doc['fieldname'].get(index)` `_score` (`double` read-only):: The similarity score of the current document. *Return* `double`:: The score for the specified document. *API* The standard <> is available. *Example* To run this example, first follow the steps in <>. To sort results by the length of the `theatre` field, submit the following query: [source,console] ---- GET /_search { "query": { "term": { "sold": "true" } }, "sort": { "_script": { "type": "number", "script": { "lang": "painless", "source": "doc['theatre'].value.length() * params.factor", "params": { "factor": 1.1 } }, "order": "asc" } } } ---- // TEST[setup:seats]