/search

GET

Default ONS query API which combines the content with type counts

Parameters

Name Type Description
q query Query search term.
content_type query Comma separated list of content types to be returned.
topics query Comma separated list of topics to be returned.
population_types query Comma separated list of population type names to filter the results (or).
dimensions query Comma separated list of dimension names to filter the results (and).
highlight query Determines whether to return HTML highlighted fields.
sort query The order to return the results.
limit query The number of items requested, defaulted to 50 and limited to 1000.
offset query The first row of resources to retrieve, starting at 0. Use this parameter as a pagination mechanism along with the limit parameter.
fromDate query Specifies candidate results by their ReleaseDate, which must be on or after the fromDate
toDate query Specifies candidate results by their ReleaseDate, which must be on or before the toDate
nlp_weighting query Runs query through NLP processors to influence search weighting

Responses

200: OK

Example value
{
  "type": "object",
  "required": [
    "count",
    "took",
    "content_types",
    "items"
  ],
  "properties": {
    "alternative_suggestions": {
      "description": "List of suggested alternative search queries from current search query",
      "type": "array",
      "items": {
        "type": "string"
      },
      "example": [
        "UK",
        "economy",
        "inflation rate"
      ]
    },
    "content_types": {
      "description": "List of content types included in results",
      "type": "array",
      "items": {
        "type": "object",
        "required": [
          "type",
          "count"
        ],
        "properties": {
          "count": {
            "type": "integer"
          },
          "type": {
            "type": "string"
          }
        }
      }
    },
    "count": {
      "description": "Number of search results which match query",
      "type": "number",
      "example": 80
    },
    "dimensions": {
      "description": "List of population types included in results",
      "type": "array",
      "items": {
        "type": "object",
        "required": [
          "type",
          "count"
        ],
        "properties": {
          "count": {
            "type": "integer"
          },
          "type": {
            "type": "string"
          }
        }
      }
    },
    "items": {
      "description": "List of matching content items for the current page",
      "type": "array",
      "items": {
        "type": "object",
        "required": [
          "description",
          "type",
          "uri"
        ],
        "properties": {
          "description": {
            "type": "object",
            "required": [
              "summary",
              "title"
            ],
            "properties": {
              "contact": {
                "type": "object",
                "required": [
                  "name",
                  "email"
                ],
                "properties": {
                  "email": {
                    "type": "string"
                  },
                  "name": {
                    "type": "string"
                  },
                  "telephone": {
                    "type": "string"
                  }
                }
              },
              "dataset_id": {
                "type": "string"
              },
              "dimensions": {
                "description": "An array of dimensions within a dataset.",
                "type": "array",
                "items": {
                  "type": "object",
                  "properties": {
                    "label": {
                      "type": "string"
                    },
                    "name": {
                      "type": "string"
                    },
                    "raw_label": {
                      "type": "string"
                    }
                  }
                }
              },
              "edition": {
                "type": "string"
              },
              "headline1": {
                "type": "string"
              },
              "headline2": {
                "type": "string"
              },
              "headline3": {
                "type": "string"
              },
              "highlight": {
                "description": "Fields that contain at least 1 matching term from query 'q' parameter. The values contain the following embedded tags \"...\u003cem class=\"highlight\"\u003e{matched term}\u003c/em\u003e...\"",
                "type": "object",
                "properties": {
                  "dataset_id": {
                    "type": "string"
                  },
                  "edition": {
                    "type": "string"
                  },
                  "keywords": {
                    "type": "array",
                    "items": {
                      "type": "string"
                    }
                  },
                  "meta_description": {
                    "type": "string"
                  },
                  "summary": {
                    "type": "string"
                  },
                  "title": {
                    "type": "string"
                  },
                  "topics": {
                    "type": "array",
                    "items": {
                      "type": "string"
                    }
                  }
                }
              },
              "keywords": {
                "type": "array",
                "items": {
                  "type": "string"
                }
              },
              "language": {
                "type": "string",
                "example": "English"
              },
              "latest_release": {
                "type": "boolean"
              },
              "meta_description": {
                "type": "string"
              },
              "national_statistic": {
                "type": "boolean"
              },
              "next_release": {
                "type": "string",
                "example": "14 August 2015"
              },
              "population_type": {
                "description": "A population type a dataset is associated with e.g. Usual-Residents.  This is applicable to Census 2021 datasets only.",
                "type": "string"
              },
              "pre_unit": {
                "type": "string"
              },
              "release_date": {
                "type": "string",
                "format": "date-time"
              },
              "source": {
                "type": "string"
              },
              "summary": {
                "type": "string"
              },
              "title": {
                "type": "string"
              },
              "topics": {
                "type": "array",
                "items": {
                  "type": "string"
                }
              },
              "unit": {
                "type": "string"
              }
            }
          },
          "type": {
            "type": "string"
          },
          "uri": {
            "type": "string"
          }
        }
      }
    },
    "population_types": {
      "description": "List of population types included in results",
      "type": "array",
      "items": {
        "type": "object",
        "required": [
          "type",
          "count"
        ],
        "properties": {
          "count": {
            "type": "integer"
          },
          "type": {
            "type": "string"
          }
        }
      }
    },
    "suggestions": {
      "description": "List of suggested alternative similar search queries",
      "type": "array",
      "items": {
        "type": "string"
      }
    },
    "took": {
      "description": "Time taken to execute query in milliseconds",
      "type": "number",
      "example": 530
    },
    "topics": {
      "description": "List of topics included in results",
      "type": "array",
      "items": {
        "type": "object",
        "required": [
          "type",
          "count"
        ],
        "properties": {
          "count": {
            "type": "integer"
          },
          "type": {
            "type": "string"
          }
        }
      }
    }
  }
}

400: Query term not specified

Example value
null

500: Internal server error

Example value
null

POST

Request a new search index and receive the name of the new index created in response. Endpoint requires service or user authentication.

Responses

200: OK

Example value
{
  "type": "object",
  "required": [
    "index_name"
  ],
  "properties": {
    "index_name": {
      "description": "Name of new empty search index",
      "type": "string",
      "example": "ons1636458168532"
    }
  }
}

500: Internal server error

Example value
null