SQL Runner provides a way to directly access your database and leverage that access in a variety of ways. Using SQL Runner, you can easily navigate the tables in your schema, use an ad hoc Explore from a SQL query, run prewritten descriptive queries on your data, see your SQL Runner history, download results, share queries, add to a LookML Project as a derived table, and perform other useful tasks.
This page describes how to run queries in SQL Runner, create ad hoc Explores, and how to use SQL Runner to debug queries. See these other documentation pages for information on:
- SQL Runner basics
- Using SQL Runner to create derived tables
- Managing database functions with SQL Runner
Running queries in SQL Runner
To run a query on your database, you can write the SQL query from scratch, use an Explore to create the query, or run a query against a LookML model. You can also use the history to rerun a previous query.
Writing a SQL query from scratch
You can use SQL Runner to write and run your own SQL queries against your database. Looker passes your query to your database just as you have written it, so be sure that the syntax of your SQL query is valid for your database dialect. For example, each dialect has slightly different SQL functions with specific parameters that should be passed to the function.
- Click in the SQL Query area and type your SQL command.
- Optionally, double-click on a table name or field from the field list to include it in your query at the cursor location.
- Click Run to run the query against your database.
- View the results in the Results area. SQL Runner will load up to 5000 rows of the query’s result set. For SQL dialects that support streaming, you can download the results to see the entire result set.
Some SQL programs will let you run multiple queries in a series. However, you can only run one query at a time in SQL Runner. SQL Runner also has a 65,535 character limit on queries, including white space.
When you have a query that you like, you can then add the query to a project, get the LookML for a derived table, or share the query.
You can also use SQL Runner to play with new queries or test existing queries. SQL Runner error highlighting helps test and debug queries.
Using an Explore to create a SQL query
You also can use an Explore to create a query, then get the SQL command for that query to use in SQL Runner:
- From an Explore, click the SQL tab from the Data bar.
- Select the text of the SQL query and copy it into SQL Runner, or
- Click Open in SQL Runner or Explain in SQL Runner to open the query in SQL Runner.
Once a query is added to the SQL Query area of SQL Runner, you can click Run to query the database. Alternatively, you can edit the query and then run the new query.
Creating visualizations with SQL Runner
If your Looker admin has enabled the SQL Runner Vis Labs feature, you can create visualizations directly in SQL Runner.
With SQL Runner Vis enabled, the SQL Runner panels are reorganized. The visualization panel appears at the top, the results panel is in the middle, and the query panel appears at the bottom.
- After a SQL query is created and run, you can open the Visualization tab to view the visualization and choose a visualization type, just as you would do on the Explore page.
- You can edit the visualization using the Settings menu.
- You can share visualizations created with SQL Runner by sharing the URL. Any customizations that you make using the visualization’s Settings menu will be saved and the link will not change.
There are some things to keep in mind about how SQL Runner visualizations work:
- The results table and visualization interpret any numeric field as a measure.
- The full field name is always used in the results table and visualization. Therefore, the Show Full Field Name option in the Settings menu is inactive.
- To use custom fields, table calculations, pivots, column totals, and subtotals, explore from your SQL Runner query.
- Static map (regions) visualizations are not supported by SQL Runner visualizations, however maps that use latitude and longitude data (map and static map (points) visualizations) are supported.
- Timeline visualizations are not supported by SQL Runner visualizations.
Pivoting dimensions
You can edit the query results to pivot by one or more dimensions in SQL Runner visualizations. To pivot a field:
- Click on a column’s gear menu in the Results area to expose column options.
- Click Pivot Column.
The pivoted results display in the SQL Runner visualization:
The results in the Results area do not appear pivoted.
To unpivot results, click the pivoted column’s gear menu and select Unpivot Column:
Changing the field type
When displaying your query’s results and visualization, SQL Runner automatically interprets any numeric field as a measure and any non-numeric field as a dimension. You can override the default field type and convert a dimension to a measure – or vice versa – by:
- Click on a column’s gear menu in the Results area to expose column options.
- Click Convert to Dimension or Convert to Measure to change the field type.
The visualization will display the new field type:
Running a query against a LookML model
You can use SQL Runner to write and run SQL queries against a LookML model, instead of directly against your database. When constructing your query against a model, you can use LookML substitution operators, such as ${view_name.field_name}
or ${view_name.SQL_TABLE_NAME}
. This can save time when constructing a query to troubleshoot a derived table, for example.
Looker resolves any LookML substitutions and then passes your query to your database, so the query should be in valid SQL for your database dialect. For example, each dialect has slightly different SQL functions with specific parameters that should be passed to the function.
To run a query against your LookML model in SQL Runner:
- Click the Model tab.
- Select the model you want to query.
- Click in the SQL Query area and enter your SQL query using LookML fields.
- Optionally, double-click on a view in the view list to include the view in your query at the cursor location.
- To see the list of fields in a view, click on the view in the Views section. Optionally, you can double-click on a field in the field list to include it in your query at the cursor location.
- In the Prepared SQL Query area, you can view the resulting SQL query that is built after any LookML substitutions have been translated to SQL.
- Click Run to run the query against your model.
- View the results in the Results area. SQL Runner loads up to 5,000 rows of the query’s result set. For SQL dialects that support streaming, you can download the results to see the entire result set.
When you have a query that you like, you can then add the query to a project, get the LookML for a derived table, or share the query.
You can also use SQL Runner to play with new queries, test existing queries, or open a new Explore from the results. SQL Runner error highlighting helps test and debug queries.
Viewing a field’s LookML from SQL Runner
From the field list in the Model tab, you can also see the LookML for a field. Hover over the field in the field list, and click the Looker icon to the right of the field name:
Looker opens up the LookML IDE, and loads the file where the field is defined.
SQL Runner history
You can also see a recent history of all queries you have run in SQL Runner.
To see your history, click the History tab at the top of the navigation pane. SQL Runner displays all the queries run on the database connection. Red indicates a query that did not run due to an error.
Click on a query in the history to populate that query into SQL Runner, then click Run to rerun the query:
Sorting your query
A table’s sort order is indicated by an upward or a downward arrow next to the sorted field name, depending on whether the results are in ascending or descending order. You can sort by multiple columns by holding down the Shift key and then clicking on the column headers in the order that you want them sorted. A field’s sort order is also indicated by a number that distinguishes its sort-by order as compared to other fields, by an arrow next to the field name that shows the sorting direction (ascending or descending), and by a pop-up that appears when you hover over a field name.
For more information and examples, see the Sorting data section of the Exploring data in Looker documentation page.
Sharing queries
You can share a query in SQL Runner with another user with SQL Runner access. To share a query, simply copy the URL in the URL bar:
Downloading results
Once you have run your SQL query, you can download the results in a variety of formats.
- Write a query in the SQL Query box. (You do not need to run the query in SQL Runner at this point.)
- Select Download from the gear menu in the upper right.
- Select the file format of the download (text file, CSV, JSON, etc.).
Click Open in Browser to see the results in a new browser window, or click Download to download the results to a file on your computer.
When you click either Open in Browser or Download, Looker will rerun the query and then perform the download.
For SQL dialects that support streaming, the SQL Runner Download option will download the entire result set. For SQL dialects that do not support streaming, the SQL Runner Download option will download only the rows of the query that are shown in the Results section (up to 5,000 rows).
Copying column values
You can copy column values from the Results section in SQL Runner. Click on a column’s gear menu to copy the values to your clipboard. From there you can paste the column values into a text file, Excel document, or other location.
If your Looker admin has enabled the SQL Runner Vis Labs feature, you have other options in the column gear menu as well:
You can also manually move, pin and resize columns in the results table.
Cost estimates for SQL Runner queries
New in Looker 22.6, you can enable cost estimates for SQL Runner queries on Amazon Aurora database connections. Also in Looker 22.6, cost estimates are enabled by default for MySQL connections and MySQL on Amazon RDS connections.
For BigQuery, MySQL, MySQL on Amazon RDS, Snowflake, Amazon Redshift, Amazon Aurora, PostgreSQL, Google Cloud PostgreSQL, and Microsoft Azure PostgreSQL connections, SQL Runner provides an estimate of the cost of the query. Once you enter the SQL query, SQL Runner will calculate the amount of data that the query will require and display the information near the Run button.
For BigQuery, MySQL, and MySQL on Amazon RDS connections, cost estimates are always enabled. For Snowflake, Amazon Redshift, Amazon Aurora, PostgreSQL, Google Cloud PostgreSQL, and Microsoft Azure PostgreSQL database connections, you must enable the Cost Estimate option for the connection. You can enable Cost Estimate when you create the connection. For existing connections, you can edit the connection from the Connections page in the Database section of Looker’s Admin panel.
Creating an ad hoc Explore
From SQL Runner you can get fast insight into the data by creating an ad hoc Explore for a SQL query or database table. You can use the Looker Explore to select fields, add filters, visualize the results, and create SQL queries.
There are two ways to open an ad hoc Explore from SQL Runner:
- Explore from SQL Runner’s query results
- Explore from SQL Runner’s table list
Exploring from SQL Runner query results
SQL Runner lets you open an Explore from a SQL query. This creates a temporary Explore from the query written in SQL Runner. That lets you test what is returned by the query, as well as visualize the results. This can be used for any query but is especially useful for testing queries you plan to use for derived tables.
If your Looker admin has enabled the SQL Runner Vis Labs feature, you can create visualizations directly in SQL Runner.
- Use SQL Runner to create the SQL query that you want to use.
- Click Explore from the gear menu in the upper right. This takes you to a new Explore, where you can explore the SQL query as if it were a saved table in your model.
- You can copy the URL to this Explore for sharing.
- To add this query as a derived table in your project directly from here, click Add View to Project.
Creating custom fields while exploring in SQL Runner
If you have access to the custom fields feature, you can use custom fields to visualize unmodeled fields in SQL Runner. As described in the previous section, click Explore from the gear menu. Then, in the field picker:
- Click the Custom Fields section to open it and then click New to begin creating a custom dimension, custom measure, or table calculation. (If you do not have the Custom Fields section, then you do not have access to create custom fields.)
- If your admin has enabled the Upgraded Explore Field Picker Labs feature, click Add.
- Click a measure’s gear menu and choose Filter Measure to create a filtered custom measure from an existing measure.
- If your admin has enabled the Upgraded Explore Field Picker Labs feature, click the measure’s three-dot Options menu.
- Click a dimension’s gear menu and choose a measure type (like sum or count) to create a custom measure from a dimension.
- If your admin has enabled the Upgraded Explore Field Picker Labs feature, click the dimension’s three-dot Options menu.
Exploring a table listed in SQL Runner
Use the Explore Table option in the Database tab to create an ad hoc Explore for any table in the connection. This lets you use Looker on a table before you’ve modeled it, exploring the table just like a LookML view.
Once you open an Explore for the table, you can decide whether to add the table to your project. You can also use the Explore’s SQL tab to see the SQL queries that Looker sends to the database, and then use the Open in SQL Runner button to bring the query back into SQL Runner.
- Click the Database tab.
- In SQL Runner, click the gear for a table and select Explore Table.
- Looker generates a temporary model with a view for the table, then displays the Explore.
- Looker provides a dimension field for each column in the table. (This is the same way that Looker generates a model at the start of a project.)
- Looker automatically includes timeframes for any date fields.
- Looker also includes a count measure.
When using the Explore Table option, there is no LookML file associated with the Explore — it is just an ad hoc view of the table.
Debugging using SQL Runner
SQL Runner is also a useful tool for checking SQL errors in queries.
SQL Runner error highlighting
SQL Runner highlights the location of errors in the SQL command and includes the position of the error in the error message:
The position information provided will vary depending on the database dialect. For example, MySQL provides the line number that contains the error, while Redshift provides the character position of the error. Other database dialects might have one of these or other behaviors.
SQL Runner also highlights the location of the first syntax error in the SQL command by underlining it in red and marking the row with an “x”. Hover over the “x” to see more information on the error. After you fix that issue, click Run to see if there are any more errors in the query.
Using SQL Runner to check errors in Explores
If you run into SQL syntax errors in an Explore, you can use SQL Runner to determine the location of the error and the type of error, such as spelling mistakes or missing commands.
- From the Explore, click the SQL tab from the Data bar.
- Click Open in SQL Runner to open the query in SQL Runner.
This copies the Explore’s generated SQL to SQL Runner. As shown above, SQL Runner highlights the location of errors in the SQL command and includes the position of the error in the error message. You can then make changes and re-run the query in SQL Runner until you have corrected the errors.
Using SQL Runner to check errors in derived tables
For information about using SQL Runner to check SQL errors in derived tables, see the Using SQL Runner to test derived tables Looker Community article.