YAML placeholders
SnowDDL supports placeholders in YAML configs. Placeholder format is similar to GitHub Actions:
Examples:
Configuration
Placeholders should be defined in config path: /placeholder.yaml
Example:
Additionally, you may specify a path to file with environment-specific placeholder values. For example, you may use it to override bucket_name
from dev-test-bucket
in DEV environment to prod-test-bucket
in PROD environment.
CLI option is --placeholder-path
:
Placeholders from command line argument
Alternatively, it is possible to specify custom placeholder values using CLI argument --placeholder-values
. This argument accepts JSON string. For example:
Data types of JSON values are important!
For example, placeholders for BOOLEAN values should be specified as JSON true
or false
without quotes. Numeric values should not have quotes as well.
Technical placeholders
A small number of placeholders are created automatically and always available. These placeholders can still be overloaded by config if necessary.
env_prefix (str) - contains current env prefix value. For example, if env prefix is
ALICE
, this placeholder will containALICE__
. It should be used as a part of raw SQL fragments when it is necessary to access object in another database. It is especially useful for VIEW definitions. For example:${{ env_prefix }}db_name.schema_name.object_name
.target_db (str) - contains target database name in SingleDB mode, including env prefix. Requires
--target-db
CLI argument to be set explicitly.
Usage notes
Data types of placeholder values are preserved. You may use integers, booleans, floats, etc.
All placeholders should be defined explicitly. Undefined placeholders will raise an exception and stop further execution to prevent an accidental damage.
Last updated