~ Licensed to the Apache Software Foundation (ASF) under one
~ or more contributor license agreements. See the NOTICE file
~ distributed with this work for additional information
~ regarding copyright ownership. The ASF licenses this file
~ to you under the Apache License, Version 2.0 (the
~ "License"); you may not use this file except in compliance
~ with the License. You may obtain a copy of the License at
~
~ http://www.apache.org/licenses/LICENSE-2.0
~
~ Unless required by applicable law or agreed to in writing,
~ software distributed under the License is distributed on an
~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
~ KIND, either express or implied. See the License for the
~ specific language governing permissions and limitations
~ under the License.
-->
This tutorial demonstrates some useful features built into Query view in Apache Druid.
Query view lets you run [Druid SQL queries](../querying/sql.md) and [native (JSON-based) queries](../querying/querying.md) against ingested data. Try out the [Introduction to Druid SQL](./tutorial-jupyter-index.md#tutorials) tutorial to learn more about Druid SQL.
You can use Query view to test and tune queries before you use them in API requests—for example, to perform [SQL-based ingestion](../api-reference/sql-ingestion-api.md). You can also ingest data directly in Query view.
The tutorial guides you through the steps to ingest sample data and query the ingested data using some Query view features.
## Prerequisites
Before you follow the steps in this tutorial, download Druid as described in the [quickstart](./index.md) and have it running on your local machine. You don't need to have loaded any data.
## Run a demo query to ingest data
Druid includes demo queries that each demonstrate a different Druid feature—for example transforming data during ingestion and sorting ingested data. Each query has detailed comments to help you learn more.
In this section you load the demo queries and run a SQL task to ingest sample data into a [table datasource](../querying/datasource.md#table).
1. Navigate to the Druid console at [http://localhost:8888](http://localhost:8888) and click **Query**.
2. Click the ellipsis at the bottom of the query window and select **Load demo queries**. Note that loading the demo queries replaces all of your current query tabs. The demo queries load in several tabs:
3. Click the **Demo 1** tab. This query ingests sample data into a datasource called **kttm_simple**. Click the **Demo 1** tab heading again and note the options—you can rename, copy, and duplicate tabs.
4. Click **Run** to ingest the data.
5. When ingestion is complete, Druid displays the time it took to complete the insert query, and the new datasource **kttm_simple** displays in the left pane.
## View and filter query results
In this section you run some queries against the new datasource and perform some operations on the query results.
1. Click **+** to the right of the existing tabs to open a new query tab.
2. Click the name of the datasource **kttm_simple** in the left pane to display some automatically generated queries:
3. Click **SELECT * FROM kttm_simple** and run the query.
4. In the query results pane, click **Chrome** anywhere it appears in the **browser** column then click **Filter on: browser = 'Chrome'** to filter the results.
## Run aggregate queries
[Aggregate functions](../querying/sql-aggregations.md) allow you to perform a calculation on a set of values and return a single value.
In this section you run some queries using aggregate functions and perform some operations on the results, using shortcut features designed to help you build your query.
1. Open a new query tab.
2. Click **kttm_simple** in the left pane to display the generated queries.
3. Click **SELECT COUNT(*) AS "Count" FROM kttm_simple** and run the query.
4. After you run a query that contains an aggregate function, additional Query view options become available.
Click the arrow to the left of the **kttm_simple** datasource to display the columns, then click the **country** column. Several options appear to apply country-based filters and aggregate functions to the query:
7. Click **Engine: auto (sql-native)** to display the engine options—**native** for native (JSON-based) queries, **sql-native** for Druid SQL queries, and **sql-msq-task** for SQL-based ingestion.
Select **auto** to let Druid select the most efficient engine based on your query input.
8. From the engine menu you can also edit the query context and turn off some query defaults.
Deselect **Use approximate COUNT(DISTINCT)** and rerun the query. The country count in the results decreases because the computation has become more exact. See [SQL aggregation functions](../querying/sql-aggregations.md) for more information.
9. Query view can provide information about a function, in case you aren't sure exactly what it does.
Delete the contents of the query line `COUNT(DISTINCT country) AS dist_country` and type `COUNT(DISTINCT)` to replace it. A help dialog for the function displays:
11. Select **Edit column** and change the **Output name** to **Distinct countries**.
## Generate an explain plan
In this section you generate an explain plan for a query. An explain plan shows the full query details and all of the operations Druid performs to execute it.
Druid optimizes queries of certain [types](../querying/sql-translation.md#query-types)—see [SQL query translation](../querying/sql-translation.md) for information on how to interpret an explain plan and use the details to improve query performance.
1. Open a new query tab.
2. Click **kttm_simple** in the left pane to display the generated queries.
3. Click **SELECT * FROM kttm_simple** and run the query.
4. Click the ellipsis at the bottom of the query window and select **Explain SQL query**. The query plan opens in a new window:
5. Click **Open in new tab**. You can review the query details and modify it as required.
6. Change the limit from 1001 to 2001:
```sql
"Limit": 2001,
```
and run the query to confirm that the updated query returns 2,001 results.
## Try out a few more features
In this section you try out a few more useful Query view features.
### Use calculator mode
Queries without a FROM clause run in calculator mode—this can be useful to help you understand how functions work. See the [Druid SQL functions](../querying/sql-functions.md) reference for more information.
1. Open a new query tab and enter the following:
```sql
SELECT SQRT(49)
```
2. Run the query to produce the result `7`.
### Download query results
You can download query results in CSV, TSV, or newline-delimited JSON format.
1. Open a new query tab and run a query, for example:
```sql
SELECT DISTINCT platform
FROM kttm_simple
```
2. Above the results pane, click the down arrow and select **Download results as… CSV**.
### View query history
In any query tab, click the ellipsis at the bottom of the query window and select **Query history**.
You can click the links on the left to view queries run at a particular date and time, and open a previously run query in a new query tab.
## Further reading
For more information on ingestion and querying data, see the following topics:
- [Quickstart](./index.md) for information on getting started with Druid.
- [Tutorial: Querying data](tutorial-query.md) for example queries to run on Druid data.
- [Ingestion](../ingestion/index.md) for an overview of ingestion and the ingestion methods available in Druid.
- [SQL-based ingestion](../multi-stage-query/index.md) for an overview of SQL-based ingestion.
- [SQL-based ingestion query examples](../multi-stage-query/examples.md) for examples of SQL-based ingestion for various use cases.