title | redirect_from | |
---|---|---|
Models |
|
Models are a fundamental building block in Metabase. Models curate data from another table or tables from the same database to anticipate the kinds of questions people will ask of the data. You can think of them as derived tables, or a special kind of saved question meant to be used as the starting point for new questions. You can base a model on a SQL or query builder question, which means you can include custom, calculated columns in your model.
Models:
- Let you update column descriptions and customize metadata to create great starting points for exploration.
- Show up higher in search results and get highlighted when other users start new questions to promote reuse.
- Live in collections to keep them separate from messy database schemas.
- Can surface individual records in search results.
For a deep dive on why and how to use models, check out our Learn article on models.
You can use models to:
- Create, uh, models, with model here meaning an intuitive description of some concept in your business that you codify as a set of columns. An example model could be a "customer", which is a table that pulls together customer information from multiple tables and adds computed columns, like adding a lifetime value (LTV) column. This model represents the measures and dimensions that you think are relevant to your understanding of your customers.
- Let people explore the results of SQL queries with the drill-through menu and query builder (provided you set the column types).
- Create summary tables that aggregate data from multiple tables.
- Clean up tables with unnecessary columns and rows filtered out.
The idea with models is to give other people a good "starting point table" that makes it easier to answer any questions they have about the subject being modeled.
First, search for models that already exist. If you can't find one that meets your needs, you can create a model:
Models you create are automatically pinned to the current collection.
- In the upper right, click New + > Model.
- Choose either the query builder or a native query (if you want to use SQL). The advantage of using the query builder is that Metabase will be able to fill out some of the metadata for you; if you use SQL, you'll have to fill out that metadata manually.
- Select your data.
- Create and save your query.
- Ask a question using either the query builder or the SQL editor, or select an existing saved question that you want to convert to a model.
- Save the question.
- Click on the ... > Turn this into a model.
To view a model's detail page:
- From a collection: click on the book icon next to a model.
- From a model: click on the info button in the upper right, then click Model details.
Here you'll see several tabs:
- Used by: lists the items based on the model.
- Schema: lists the fields in the model.
- Actions: lists the actions in the model, and allows you to create new actions.
The model detail page also shows some basic info about the model:
- Description
- Contact (who wrote the model)
- Backing table(s)
To start a new question based on the model, click Explore.
To edit the model's underlying query, click Edit definition.
You can also edit the model's metadata.
Metadata is the secret sauce of models. When you write a SQL query, Metabase can display the results, but it can't "know" what kind of data it's returning (like it can with questions built using the query builder). What this means in practice is that people won't be able to drill-through the results, or explore the results with the query builder, because Metabase doesn't understand what the results are. With models, however, you can tell Metabase what kind of data is in each returned column so that Metabase can still do its drill-through magic. Metadata will also make filtering nicer by showing the correct filter widget, and it will help Metabase to pick the right visulization for the results.
If you only set one kind of metadata, set the Column type to let Metabase know what kind of data it's working with.
What people will see as the column's name.
A place to write helpful context for the column.
For models based on SQL queries, you can tell Metabase if the column has the same type as an existing database column.
You can set the column type. The default is "No special type".
If your model is based on a SQL query and you want people to be able to explore the results with the query builder and drill-through menu, you'll need to set the column type for each column in your model.
You can specify whether a column should appear in the table view, or just in a detail view (when you click on the entity/primary key for the row).
- Table and detail views
- Detail views only
- Text
- Link (it's a URL people should be able to click on)
For string fields in records with integer entity keys, Metabase will give you the option make the values in that field show up when people search your Metabase. Essentially, Metabase will index these values and make them available to Metabase's search engine. This option is handy when people often want to jump straight to an individual record in your model.
For example, if you have a model with accounts, you could turn on this option for a column listing the account's name or email so that people can quickly search for specific accounts in the model from anywhere in your Metabase. When people click on a record in the search results, Metabase will jump straight to the model and the object detail for that record.
There are some limitations to this indexing:
- The indexed field must be a text/string type.
- The record containing the field must have an integer entity key.
- To keep your search speedy, Metabase will only index 5000 unique values from that field, so this option isn't the best choice to turn on for tables with a ton of records.
You can edit a model's query by clicking on the down arrow next to the model's name and clicking on Edit query definition. When you're doing editing, be sure to save your changes. Unlike questions, which prompt you to save as a new question, any changes here will overwrite the existing model. If you want to create a new model from an existing model, select Duplicate this model from the model sidebar (the icon of two overlapping squares).
See asking questions.
You can refer to a model in a SQL query just like you can refer to a saved question:
{% raw %}
SELECT * FROM {{#1-customer-model}}
{% endraw %}
Or as a common table expression (CTE):
{% raw %}
WITH model AS {{#3807-invoice-model}}
SELECT *
FROM model;
{% endraw %}
Simply typing {% raw %}{{#}} {% endraw %}
will allow you to search for models (for example, you could type in {% raw %}{{#customer}}{% endraw %}
to search models, questions, and tables with the word "customer" in the title.
You can also use the data reference sidebar to browse the models available. To open the data reference sidebar, click on the book icon.
For questions, dashboards, and models, Metabase keeps a version history for the previous fifteen versions of that item. You can view changes, revert to previous versions, and archive outdated items.
See History.
{% include plans-blockquote.html feature="Model verification" %}
Just like with a question, admins can verify models. Verifying a model will give it a check mark to let others know an admin vetted the model. If anyone makes any changes to the model, the check mark will disappear. An admin will have to verify the question again to restore the check mark.
Currently available for PostgreSQL, MySQL, and Redshift.
Metabase can cache the results of your models so that the models load faster. Metabase caches models by creating tables in a bespoke schema in your data warehouse, and saves the results of the queries that underlie your models in those tables. When people ask questions based on your models, Metabase will substitute those cached results in place of running the model's query.
To set up model caching:
Model caching doesn't work with data sandboxing.
Go to Admin settings > Settings > Caching > Models to turn the feature on.
You can set models to refresh based on one of the default frequencies, or select the Custom option to use cron syntax to specify your own caching update frequency. We recommend scheduling the cache to refresh on a frequency that makes sense with how often your source tables update with new data. The cron scheduler uses the Report Timezone if selected and otherwise uses the System Timezone (which defaults to GMT in Metabase Cloud).
If someone changes the query definition of a model, any question based on that model will skip the cache until the next cache refresh.
Go to Admin settings > Databases > your database > Turn model caching on.
If the credentials you've given Metabase to connect to your database are permissive, Metabase should do all the work for you: Metabase will check if the schema exists, or otherwise attempt to create it.
If the connection's credentials lack the necessary permissions to create the schema in your database, you'll need to create the schema in the database yourself:
-
Click on the info icon to get the schema name.
In the above image, the schema name is "metabase_cache_134ba_7", but your schema name will differ.
-
Create the schema in your database---make sure you use the exact schema name from step 1.
-
Ensure that the credentials Metabase uses can manage and write to that schema.
To refresh a model's cached results, go to the model and click on the i info icon. In the info sidebar that opens, you'll see a note about when Metabase last refreshed the model's cache, and an icon to refresh the cache.
You can view the logs for model caching by clicking on the gear icon in the upper right and selecting Admin settings > Tools > Model caching logs. See Admin tools.
{% include plans-blockquote.html feature="Caching individual models" %}
On some paid plans, you can also toggle caching on or off for individual models. When viewing a model, click on the ... in the upper right and select Turn model caching on/off.