Model SQL
When using Rill Developer, data transformations are powered by DuckDB and their dialect of SQL. Under the hood, by default, data models are created as views in DuckDB. Please check our modeling page and DuckDB documentation for more details about how to construct and write your model SQL syntax.
In your Rill project directory, you can also create a <model_name>.sql
file containing an appropriate DuckDB SELECT
statement, most commonly within the default models
directory, to represent a model (or set of SQL transformations). Rill will automatically detect and parse the model next time you run rill start
.
Rill will automatically assume any .sql
file within the Rill project directory to be a model, including .sql
files that might be nested under multiple levels or within subfolders in a directory (such as models
). Models are unique in that they are a resource that doesn't necessarily need the type
property specified.
Annotating your models with properties
In most cases, objects are represented in Rill as YAML files. Models are unique in that any <model>.sql
file can be considered a model resource in Rill, representing a SQL transformation that you would like to inform using a set of inputs and outputting a view or table (depending on the materialization type). For most other resources, available properties can be set directly via the corresponding YAML file. In the case of a model SQL file though, configurable properties should be set by annotating the top of the file using the following syntax:
-- @property: value
We will cover different available configurable properties in the below sections.
Marking your model SQL file as a model resource type
By default, any new model that is created in a Rill project will populate a corresponding .sql
file representing the model. Similarly, a .sql
file that is directly created in the project directory will also be automatically assumed by Rill to be a model by default. Therefore, it is not necessary to annotate the model resource with the type
property.
For consistency or documentation purposes, if you'd like to annotate your model resource as well with the type
property, you can do so by adding the following to the top of your <model_name>.sql
:
-- @type: model
This only applies to models as models are defined using SQL files. For other resources whose configuration is handled in YAML, the type
property is still required.
Model materialization
As mentioned, models will be materialized in DuckDB as views by default. However, you can choose to materialize them as tables instead of views. To do this, you can add the following annotation to the top of your model SQL file:
-- @materialize: true
Alternatively, it is possible to set it as a project-wide default as well that your models inherit via your rill.yaml
file:
models:
materialize: true
There are both pros and cons to materializing your models.
- Pros can include improved performance for downstream models and dashboards, especially with the SQL is complex and/or the data size is large. We generally recommend materializing final models that power dashboards (we do this automatically in Rill Cloud).
- Cons can include a degraded keystroke-by-keystroke modeling experience or for specific edge cases, such as when using cross joins.
If unsure, we would generally recommend leaving the defaults and/or reaching out for further guidance!