mirror of
https://github.com/apache/superset.git
synced 2026-04-11 12:26:05 +00:00
* setup docusaurus
* rename
* add introduction content
* chore(docsV2): move content from docs to docsV2 (#17714)
* add FAQs and contribution pages
* chore: add api, security, and roadmap pages, include swaggerui in dependency for api page
* chore: move api page header below imports
* chore: change API page info alert to use built in Infima class instead of custom class
Co-authored-by: Corbin Robb <corbin@Corbins-MacBook-Pro.local>
* chore(docs-v2): moving more markdown content to new documentation site (#17736)
* chore: move markdown content and images for docs installation directory to docs-v2
* chore: move docs miscellaneous directory content to docs-v2
* chore(docs-v2): move over connecting to databases content and rename some files to .mdx
Co-authored-by: Corbin Robb <corbin@Corbins-MacBook-Pro.local>
* Update styling and logo (#17990)
* update styling
* update colors
* chore(docs-v2): remove blog and tutorial and update some styling (#17929)
* add superset logo and favicon, change styles to better match current docs, add prettierrc
* change file types to mdx
* Add simple superset dark mode freindly logo
* clean up default pages - blog and tutorial docs
Co-authored-by: Corbin Robb <corbin@Corbins-MacBook-Pro.local>
* Chore: moving charts and dashboard to docusaurus (#18036)
* add contributing add creating charts and dashboards
* delete extra images
* update rat-excludes
* Port homepage (#18115)
* Port community page (#18128)
* chore: add seo redirects for Docs v@ (#18092)
* fix: handle null values in time-series table (#18039)
* cleanup column_type_mappings (#17569)
Signed-off-by: Đặng Minh Dũng <dungdm93@live.com>
* important change to MakeFile (#18037)
* Update superset-e2e.yml (#18041)
* Revert "Update superset-e2e.yml (#18041)" (#18051)
This reverts commit b5652739c9.
* feat: Trino Authentications (#17593)
* feat: support Trino Authentications
Signed-off-by: Đặng Minh Dũng <dungdm93@live.com>
* docs: Trino Authentications
Signed-off-by: Đặng Minh Dũng <dungdm93@live.com>
* chore(supeset.utils.core): move all database utils to database utils module (#18058)
* chore(plugin-chart-echarts): add types to controls (#18059)
* fix(generator): more cleanup to plugin framework (#18027)
* fix(generator): more cleanup to plugin framework
* fix typo and package name
* add docs
* fix typo
* Update superset-frontend/webpack.config.js
Co-authored-by: Kamil Gabryjelski <kamil.gabryjelski@gmail.com>
* fix generator reference
* add steps to tutorial and fix package version
* refine docs/readme
Co-authored-by: Kamil Gabryjelski <kamil.gabryjelski@gmail.com>
* feat(advanced analytics): support groupby in resample (#18045)
* fix(dashboard): scope of nativefilter not update (#18048)
* fix(generator): add lockfile and fix styling issues (#18073)
* fix(generator): add lockfile and fix styling issues
* fix margins and remove redundant scroll
* update tutorial
* refactor(sql_lab): SQL Lab Persistent Saved State (#17771)
* a lot of console logs
* testing
* test
* added saved_query to remoteId
* created useEffect so that title properly changes in modal
* Update superset-frontend/src/SqlLab/actions/sqlLab.js
Co-authored-by: Lyndsi Kay Williams <55605634+lyndsiWilliams@users.noreply.github.com>
Co-authored-by: Lyndsi Kay Williams <55605634+lyndsiWilliams@users.noreply.github.com>
* refactor(example_data): replace the way the birth_names data is loaded to DB (#18060)
* refactor: replace the way the birth_names data is loaded to DB
* fix failed unit test
* fix failed unit test
* fix failed tests
* fix pass wrong flag of support datetime type
* remove unused fixture
* feat: add chart description in info tooltip (#17207)
* feat: add chart list description
* fix: text overflow
* fix: text-overflow with line-height
* Correction of proper names format in README (#18087)
* chore: added SEO routes
* fix can't use examples helpers on non app context based environment (#18086)
* chore: split CLI into multiple files (#18082)
* chore: split CLI into multiple files
* Update tests
* Who fixes the fixtures?
* Add subcommands dynamically
* Rebase
* fix misspelling (#18097)
* refactor: sqleditorleftbar to functional (#17807)
* Working on converting sqleditorleftbar to functional component
* Creating draft PR to address bug
* Still working on solving re rendering bug
* infinite rerender fix
* Creating draft PR to address bug
* Cleaning up in preparation for push
* Made changes suggested by Elizabeth
* Fixed issues as per Lindsey's comment
Co-authored-by: Arash <arash.afghahi@gmail.com>
* fix rat excludes and headers
* fix(docs): fix path of image for "Create New Chart" (#18089)
* Migrate Checkbox story to tsx - see #18100 (#18101)
Looks good!
* refactor: migrate RowCountLabel to TypeScript & added story (#18105)
* enable superbook for explore component
* migrate RowCountLabel to TypeScript
* add storybook for RowCountLabel
* fix: logging warning on dataframe (don't use python's warnings) (#18111)
* fix: logging warning on dataframe (don't use python's warnings)
* lint
* update changelog and updating for 1.4.0 (#18083)
* feat: Adds a key-value endpoint to store charts form data (#17882)
* feat: Adds a key-value endpoint to store charts form data
* Fixes linting problems
* Removes the query_params from the endpoints
* Refactors the commands
* Removes unused imports
* Changes the parameters to use dataclass
* Adds more access tests
* Gets the first dataset while testing
* Adds unit tests for the check_access function
* Changes the can_access check
* Always check for dataset access
* fix(explore): fix chart embed code modal glitch (#17843)
* feat(plugin-chart-echarts): support non-timeseries x-axis (#17917)
* feat(plugin-chart-echarts): support non-timeseries x-axis
* fix tests
* change formula return type from Date to number
* add x_axis test coverage
* rename func and improve coverage
* add x-axis control to bar chart
* remove redundant console.log
* fix description
* make x-axis control mandatory
* 🙃
* fix x-axis formatter
* fix showValues
* fix implicit rDTTM_ALIAS references in postProcessing
* replace TIME_COLUMN with DTTM_ALIAS
* fix remaining implicit indexes
* fix: Disable filtering on wide result sets (#18021)
* fix: handle null values in time-series table (#18039)
* cleanup column_type_mappings (#17569)
Signed-off-by: Đặng Minh Dũng <dungdm93@live.com>
* important change to MakeFile (#18037)
* add missing is_timeseries to pivot op
Co-authored-by: Erik Ritter <erik.ritter@airbnb.com>
Co-authored-by: Grace Guo <grace.guo@airbnb.com>
Co-authored-by: Đặng Minh Dũng <dungdm93@live.com>
Co-authored-by: AAfghahi <48933336+AAfghahi@users.noreply.github.com>
* feat(country-map): added new countries in country-chart-map (#18081)
* chore: migrating storybook jsx to typescript #18100 (#18133)
* Migrating storybook jsx to typescript #18100
* Migrating storybook jsx to typescript
Co-authored-by: Jayakrishnan Karolil <jayakrishnan.karolil@nielsen.com>
* feat(annotation): add toast feedback to annotation templates (#18116)
* feat(dashboard): add toast feedback to dashboard actions (#18114)
* feat(explore): more toast feedback on user actions in Explore (#18108)
* feat(explore): add toasts feedback when user copies chart url
* Show toast message when updating chart properties
* Change toast type to success when saving chart
* Use success toast from props
* Fix tests
* Use withToasts instead of dispatch
* Use PropertiesModalProps instead of any
* Docs: fix typo (#18125)
* fix: undefined error when adding extra sequential color scheme (#18152)
* feat: allow assets to be managed externally (#18093)
* feat: allow assets to be managed externally
* Use server_default
* chore: use pkg_resources for cleaner config (#18130)
* refactor: Moves the Explore form_data endpoint (#18151)
* refactor: Moves the Explore form_data endpoint
* Removes unused imports
* Fixes openapi schema error
* Fixes typo
* Renames and UPDATING.md
Co-authored-by: Grace Guo <grace.guo@airbnb.com>
Co-authored-by: Đặng Minh Dũng <dungdm93@live.com>
Co-authored-by: AAfghahi <48933336+AAfghahi@users.noreply.github.com>
Co-authored-by: Hugh A. Miles II <hughmil3s@gmail.com>
Co-authored-by: ofekisr <35701650+ofekisr@users.noreply.github.com>
Co-authored-by: Ville Brofeldt <33317356+villebro@users.noreply.github.com>
Co-authored-by: Kamil Gabryjelski <kamil.gabryjelski@gmail.com>
Co-authored-by: Yongjie Zhao <yongjie.zhao@gmail.com>
Co-authored-by: Stephen Liu <750188453@qq.com>
Co-authored-by: Lyndsi Kay Williams <55605634+lyndsiWilliams@users.noreply.github.com>
Co-authored-by: Adam Dobrawy <ad-m@users.noreply.github.com>
Co-authored-by: Beto Dealmeida <roberto@dealmeida.net>
Co-authored-by: Emily Wu <86927881+em0227@users.noreply.github.com>
Co-authored-by: Josue Lugaro <82119536+JosueLugaro@users.noreply.github.com>
Co-authored-by: Arash <arash.afghahi@gmail.com>
Co-authored-by: Ville Brofeldt <ville.v.brofeldt@gmail.com>
Co-authored-by: Daniel Vaz Gaspar <danielvazgaspar@gmail.com>
Co-authored-by: Elizabeth Thompson <eschutho@gmail.com>
Co-authored-by: Michael S. Molina <70410625+michael-s-molina@users.noreply.github.com>
Co-authored-by: Erik Ritter <erik.ritter@airbnb.com>
Co-authored-by: Hammad-Raza <hammadraza42@hotmail.com>
Co-authored-by: jayakrishnankk <kk.jayakrishnan@gmail.com>
Co-authored-by: Jayakrishnan Karolil <jayakrishnan.karolil@nielsen.com>
Co-authored-by: Farid Rener <proteusvacuum@users.noreply.github.com>
* remove unneeded requirement
Co-authored-by: Corbin Robb <31329271+corbinrobb@users.noreply.github.com>
Co-authored-by: Corbin Robb <corbin@Corbins-MacBook-Pro.local>
Co-authored-by: Daniel W <61300812+The-hyphen-user@users.noreply.github.com>
Co-authored-by: Geido <60598000+geido@users.noreply.github.com>
Co-authored-by: Srini Kadamati <skadamat@gmail.com>
Co-authored-by: Grace Guo <grace.guo@airbnb.com>
Co-authored-by: Đặng Minh Dũng <dungdm93@live.com>
Co-authored-by: AAfghahi <48933336+AAfghahi@users.noreply.github.com>
Co-authored-by: ofekisr <35701650+ofekisr@users.noreply.github.com>
Co-authored-by: Ville Brofeldt <33317356+villebro@users.noreply.github.com>
Co-authored-by: Kamil Gabryjelski <kamil.gabryjelski@gmail.com>
Co-authored-by: Yongjie Zhao <yongjie.zhao@gmail.com>
Co-authored-by: Stephen Liu <750188453@qq.com>
Co-authored-by: Lyndsi Kay Williams <55605634+lyndsiWilliams@users.noreply.github.com>
Co-authored-by: Adam Dobrawy <ad-m@users.noreply.github.com>
Co-authored-by: Beto Dealmeida <roberto@dealmeida.net>
Co-authored-by: Emily Wu <86927881+em0227@users.noreply.github.com>
Co-authored-by: Josue Lugaro <82119536+JosueLugaro@users.noreply.github.com>
Co-authored-by: Arash <arash.afghahi@gmail.com>
Co-authored-by: Ville Brofeldt <ville.v.brofeldt@gmail.com>
Co-authored-by: Daniel Vaz Gaspar <danielvazgaspar@gmail.com>
Co-authored-by: Elizabeth Thompson <eschutho@gmail.com>
Co-authored-by: Michael S. Molina <70410625+michael-s-molina@users.noreply.github.com>
Co-authored-by: Erik Ritter <erik.ritter@airbnb.com>
Co-authored-by: Hammad-Raza <hammadraza42@hotmail.com>
Co-authored-by: jayakrishnankk <kk.jayakrishnan@gmail.com>
Co-authored-by: Jayakrishnan Karolil <jayakrishnan.karolil@nielsen.com>
Co-authored-by: Farid Rener <proteusvacuum@users.noreply.github.com>
274 lines
9.1 KiB
Plaintext
274 lines
9.1 KiB
Plaintext
---
|
|
title: SQL Templating
|
|
hide_title: true
|
|
sidebar_position: 10
|
|
version: 1
|
|
---
|
|
|
|
## SQL Templating
|
|
|
|
### Jinja Templates
|
|
|
|
SQL Lab and Explore supports [Jinja templating](https://jinja.palletsprojects.com/en/2.11.x/) in queries.
|
|
To enable templating, the `ENABLE_TEMPLATE_PROCESSING` feature flag needs to be enabled in
|
|
`superset_config.py`. When templating is enabled, python code can be embedded in virtual datasets and
|
|
in Custom SQL in the filter and metric controls in Explore. By default, the following variables are
|
|
made available in the Jinja context:
|
|
|
|
- `columns`: columns which to group by in the query
|
|
- `filter`: filters applied in the query
|
|
- `from_dttm`: start `datetime` value from the selected time range (`None` if undefined)
|
|
- `to_dttm`: end `datetime` value from the selected time range (`None` if undefined)
|
|
- `groupby`: columns which to group by in the query (deprecated)
|
|
- `metrics`: aggregate expressions in the query
|
|
- `row_limit`: row limit of the query
|
|
- `row_offset`: row offset of the query
|
|
- `table_columns`: columns available in the dataset
|
|
- `time_column`: temporal column of the query (`None` if undefined)
|
|
- `time_grain`: selected time grain (`None` if undefined)
|
|
|
|
For example, to add a time range to a virtual dataset, you can write the following:
|
|
|
|
```sql
|
|
SELECT * from tbl where dttm_col > '{{ from_dttm }}' and dttm_col < '{{ to_dttm }}'
|
|
```
|
|
|
|
To add custom functionality to the Jinja context, you need to to to overload the default Jinja
|
|
context in your environment by defining the `JINJA_CONTEXT_ADDONS` in your superset configuration
|
|
(`superset_config.py`). Objects referenced in this dictionary are made available for users to use
|
|
where the Jinja context is made available.
|
|
|
|
```python
|
|
JINJA_CONTEXT_ADDONS = {
|
|
'my_crazy_macro': lambda x: x*2,
|
|
}
|
|
```
|
|
|
|
Besides default Jinja templating, SQL lab also supports self-defined template processor by setting
|
|
the `CUSTOM_TEMPLATE_PROCESSORS` in your superset configuration. The values in this dictionary
|
|
overwrite the default Jinja template processors of the specified database engine. The example below
|
|
configures a custom presto template processor which implements its own logic of processing macro
|
|
template with regex parsing. It uses the `$` style macro instead of `{{ }}` style in Jinja
|
|
templating.
|
|
|
|
By configuring it with `CUSTOM_TEMPLATE_PROCESSORS`, a SQL template on a presto database is
|
|
processed by the custom one rather than the default one.
|
|
|
|
```python
|
|
def DATE(
|
|
ts: datetime, day_offset: SupportsInt = 0, hour_offset: SupportsInt = 0
|
|
) -> str:
|
|
"""Current day as a string."""
|
|
day_offset, hour_offset = int(day_offset), int(hour_offset)
|
|
offset_day = (ts + timedelta(days=day_offset, hours=hour_offset)).date()
|
|
return str(offset_day)
|
|
|
|
class CustomPrestoTemplateProcessor(PrestoTemplateProcessor):
|
|
"""A custom presto template processor."""
|
|
|
|
engine = "presto"
|
|
|
|
def process_template(self, sql: str, **kwargs) -> str:
|
|
"""Processes a sql template with $ style macro using regex."""
|
|
# Add custom macros functions.
|
|
macros = {
|
|
"DATE": partial(DATE, datetime.utcnow())
|
|
} # type: Dict[str, Any]
|
|
# Update with macros defined in context and kwargs.
|
|
macros.update(self.context)
|
|
macros.update(kwargs)
|
|
|
|
def replacer(match):
|
|
"""Expand $ style macros with corresponding function calls."""
|
|
macro_name, args_str = match.groups()
|
|
args = [a.strip() for a in args_str.split(",")]
|
|
if args == [""]:
|
|
args = []
|
|
f = macros[macro_name[1:]]
|
|
return f(*args)
|
|
|
|
macro_names = ["$" + name for name in macros.keys()]
|
|
pattern = r"(%s)\s*\(([^()]*)\)" % "|".join(map(re.escape, macro_names))
|
|
return re.sub(pattern, replacer, sql)
|
|
|
|
CUSTOM_TEMPLATE_PROCESSORS = {
|
|
CustomPrestoTemplateProcessor.engine: CustomPrestoTemplateProcessor
|
|
}
|
|
```
|
|
|
|
SQL Lab also includes a live query validation feature with pluggable backends. You can configure
|
|
which validation implementation is used with which database engine by adding a block like the
|
|
following to your configuration file:
|
|
|
|
```python
|
|
FEATURE_FLAGS = {
|
|
'SQL_VALIDATORS_BY_ENGINE': {
|
|
'presto': 'PrestoDBSQLValidator',
|
|
}
|
|
}
|
|
```
|
|
|
|
The available validators and names can be found in
|
|
[sql_validators](https://github.com/apache/superset/tree/master/superset/sql_validators).
|
|
|
|
### Available Macros
|
|
|
|
In this section, we'll walkthrough the pre-defined Jinja macros in Superset.
|
|
|
|
**Current Username**
|
|
|
|
The `{{ current_username() }}` macro returns the username of the currently logged in user.
|
|
|
|
If you have caching enabled in your Superset configuration, then by defaul the the `username` value will be used
|
|
by Superset when calculating the cache key. A cache key is a unique identifer that determines if there's a
|
|
cache hit in the future and Superset can retrieve cached data.
|
|
|
|
You can disable the inclusion of the `username` value in the calculation of the
|
|
cache key by adding the following parameter to your Jinja code:
|
|
|
|
```
|
|
{{ current_username(add_to_cache_keys=False) }}
|
|
```
|
|
|
|
**Current User ID**
|
|
|
|
The `{{ current_user_id()}}` macro returns the user_id of the currently logged in user.
|
|
|
|
If you have caching enabled in your Superset configuration, then by defaul the the `user_id` value will be used
|
|
by Superset when calculating the cache key. A cache key is a unique identifer that determines if there's a
|
|
cache hit in the future and Superset can retrieve cached data.
|
|
|
|
You can disable the inclusion of the `user_id` value in the calculation of the
|
|
cache key by adding the following parameter to your Jinja code:
|
|
|
|
```
|
|
{{ current_user_id(add_to_cache_keys=False) }}
|
|
```
|
|
|
|
**Custom URL Parameters**
|
|
|
|
The `{{ url_param('custom_variable') }}` macro lets you define arbitrary URL
|
|
parameters and reference them in your SQL code.
|
|
|
|
Here's a concrete example:
|
|
|
|
- You write the following query in SQL Lab:
|
|
|
|
```
|
|
SELECT count(*)
|
|
FROM ORDERS
|
|
WHERE country_code = '{{ url_param('countrycode') }}'
|
|
```
|
|
|
|
- You're hosting Superset at the domain www.example.com and you send your
|
|
coworker in Spain the following SQL Lab URL `www.example.com/superset/sqllab?countrycode=ES`
|
|
and your coworker in the USA the following SQL Lab URL `www.example.com/superset/sqllab?countrycode=US`
|
|
- For your coworker in Spain, the SQL Lab query will be rendered as:
|
|
|
|
```
|
|
SELECT count(*)
|
|
FROM ORDERS
|
|
WHERE country_code = 'ES'
|
|
```
|
|
|
|
- For your coworker in the USA, the SQL Lab query will be rendered as:
|
|
|
|
```
|
|
SELECT count(*)
|
|
FROM ORDERS
|
|
WHERE country_code = 'US'
|
|
```
|
|
|
|
**Explicitly Including Values in Cache Key**
|
|
|
|
The `{{ cache_key_wrapper() }}` function explicitly instructs Superset to add a value to the
|
|
accumulated list of values used in the the calculation of the cache key.
|
|
|
|
This function is only needed when you want to wrap your own custom function return values
|
|
in the cache key. You can gain more context
|
|
[here](https://github.com/apache/superset/blob/efd70077014cbed62e493372d33a2af5237eaadf/superset/jinja_context.py#L133-L148).
|
|
|
|
Note that this function powers the caching of the `user_id` and `username` values
|
|
in the `current_user_id()` and `current_username()` function calls (if you have caching enabled).
|
|
|
|
**Filter Values**
|
|
|
|
You can retrieve the value for a specific filter as a list using `{{ filter_values() }}`.
|
|
|
|
This is useful if:
|
|
|
|
- you want to use a filter component to filter a query where the name of filter component column doesn't match the one in the select statement
|
|
- you want to have the ability for filter inside the main query for performance purposes
|
|
|
|
Here's a concrete example:
|
|
|
|
```
|
|
SELECT action, count(*) as times
|
|
FROM logs
|
|
WHERE
|
|
action in ({{ "'" + "','".join(filter_values('action_type')) + "'" }})
|
|
GROUP BY action
|
|
```
|
|
|
|
**Filters for a Specific Column**
|
|
|
|
The `{{ get_filters() }}` macro returns the filters applied to a given column. In addition to
|
|
returning the values (similar to how `filter_values()` does), the `get_filters()` macro
|
|
returns the operator specified in the Explore UI.
|
|
|
|
This is useful if:
|
|
|
|
- you want to handle more than the IN operator in your SQL clause
|
|
- you want to handle generating custom SQL conditions for a filter
|
|
- you want to have the ability to filter inside the main query for speed purposes
|
|
|
|
Here's a concrete example:
|
|
|
|
```
|
|
WITH RECURSIVE
|
|
superiors(employee_id, manager_id, full_name, level, lineage) AS (
|
|
SELECT
|
|
employee_id,
|
|
manager_id,
|
|
full_name,
|
|
1 as level,
|
|
employee_id as lineage
|
|
FROM
|
|
employees
|
|
WHERE
|
|
1=1
|
|
|
|
{# Render a blank line #}
|
|
{%- for filter in get_filters('full_name', remove_filter=True) -%}
|
|
|
|
{%- if filter.get('op') == 'IN' -%}
|
|
AND
|
|
full_name IN ( {{ "'" + "', '".join(filter.get('val')) + "'" }} )
|
|
{%- endif -%}
|
|
|
|
{%- if filter.get('op') == 'LIKE' -%}
|
|
AND
|
|
full_name LIKE {{ "'" + filter.get('val') + "'" }}
|
|
{%- endif -%}
|
|
|
|
{%- endfor -%}
|
|
UNION ALL
|
|
SELECT
|
|
e.employee_id,
|
|
e.manager_id,
|
|
e.full_name,
|
|
s.level + 1 as level,
|
|
s.lineage
|
|
FROM
|
|
employees e,
|
|
superiors s
|
|
WHERE s.manager_id = e.employee_id
|
|
)
|
|
|
|
SELECT
|
|
employee_id, manager_id, full_name, level, lineage
|
|
FROM
|
|
superiors
|
|
order by lineage, level
|
|
```
|