snow dcm deploy¶
Deploys local project changes to Snowflake by creating, altering, or dropping objects to match your definition files.
Syntax¶
Arguments¶
identifierIdentifier of DCM Project. Example: MY_DB.MY_SCHEMA.MY_PROJECT. Supports fully qualified (recommended) or simple names. If unqualified, it defaults to the connection’s database and schema. Optional if
--targetordefault_targetis defined in the manifest.
Options¶
--from PATHLocal directory path containing DCM project files. Omit to use current directory.
--variable, -D TEXTVariables for the execution context; for example:
-D "<key>=<value>".--alias TEXTAlias for the deployment.
--target TEXTTarget profile from
manifest.ymlto use. Usesdefault_targetif not specified.--save-outputSave command response and artifacts to local ‘out/’ directory. Default: False.
--connection, -c, --environment TEXTName of the connection, as defined in your
config.tomlfile. Default:default.--host TEXTHost address for the connection. Overrides the value specified for the connection.
--port INTEGERPort for the connection. Overrides the value specified for the connection.
--account, --accountname TEXTName assigned to your Snowflake account. Overrides the value specified for the connection.
--user, --username TEXTUsername to connect to Snowflake. Overrides the value specified for the connection.
--password TEXTSnowflake password. Overrides the value specified for the connection.
--authenticator TEXTSnowflake authenticator. Overrides the value specified for the connection.
--workload-identity-provider TEXTWorkload identity provider (AWS, AZURE, GCP, OIDC). Overrides the value specified for the connection.
--private-key-file, --private-key-path TEXTSnowflake private key file path. Overrides the value specified for the connection.
--token TEXTOAuth token to use when connecting to Snowflake.
--token-file-path TEXTPath to file with an OAuth token to use when connecting to Snowflake.
--database, --dbname TEXTDatabase to use. Overrides the value specified for the connection.
--schema, --schemaname TEXTDatabase schema to use. Overrides the value specified for the connection.
--role, --rolename TEXTRole to use. Overrides the value specified for the connection.
--warehouse TEXTWarehouse to use. Overrides the value specified for the connection.
--temporary-connection, -xUses a connection defined with command-line parameters, instead of one defined in config. Default: False.
--mfa-passcode TEXTToken to use for multi-factor authentication (MFA).
--enable-diagWhether to generate a connection diagnostic report. Default: False.
--diag-log-path TEXTPath for the generated report. Defaults to system temporary directory. Default: <system_temporary_directory>.
--diag-allowlist-path TEXTPath to a JSON file that contains allowlist parameters.
--oauth-client-id TEXTValue of client id provided by the Identity Provider for Snowflake integration.
--oauth-client-secret TEXTValue of the client secret provided by the Identity Provider for Snowflake integration.
--oauth-authorization-url TEXTIdentity Provider endpoint supplying the authorization code to the driver.
--oauth-token-request-url TEXTIdentity Provider endpoint supplying the access tokens to the driver.
--oauth-redirect-uri TEXTURI to use for authorization code redirection.
--oauth-scope TEXTScope requested in the Identity Provider authorization request.
--oauth-disable-pkceDisables Proof Key for Code Exchange (PKCE). Default:
False.--oauth-enable-refresh-tokensEnables a silent re-authentication when the actual access token becomes outdated. Default:
False.--oauth-enable-single-use-refresh-tokensWhether to opt-in to single-use refresh token semantics. Default:
False.--client-store-temporary-credentialStore the temporary credential.
--format [TABLE|JSON|JSON_EXT|CSV]Specifies the output format. Default: TABLE.
--verbose, -vDisplays log entries for log levels
infoand higher. Default: False.--debugDisplays log entries for log levels
debugand higher; debug logs contain additional information. Default: False.--silentTurns off intermediate output to console. Default: False.
--enhanced-exit-codesDifferentiate exit error codes based on failure type. Default: False.
--decimal-precision INTEGERNumber of decimal places to display for decimal values. Uses Python’s default precision if not specified. [env var: SNOWFLAKE_DECIMAL_PRECISION].
--helpDisplays the help text for this command.
Usage notes¶
The snow dcm deploy command deploys local project changes to Snowflake by creating, altering, or dropping objects to match definition files.
When you deploy a DCM project, the following actions are performed:
Objects that are defined but don’t exist yet are created.
Objects that already exist but differ from the current definition are altered.
Objects that already exist and there are no differences between their state and definition stay unchanged.
Objects that already exist but are no longer defined are dropped.
Objects that existed before, and their definitions were recently added into DCM project, are added to objects managed by this DCM project.
Note
This command automatically uploads local source SQL files to a temporary stage in Snowflake so their content impacts the final result of the operation.
Use the --save-output option to save the deployment results to a local out/deploy.json file.
For more information about the deployment process, see Deploy a DCM project.
Examples¶
Deploy a DCM project object with the default options, where the project name is specified in the target identified by the
default_targetproperty in the manifest:Deploy a DCM project object where the project name is specified in the
DEVtarget in the manifest:Deploy a DCM project object with an explicit fully qualified name:
Deploy a DCM project project where the project name is specified in the
DEVtarget in the manifest, specify the value for thedb_namevariable, and set the deployment alias tov3:Deploy a DCM project object from a specific directory and save output: