Liquibase Enterprise was formerly known as Datical DB.

Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 3 Next »

Qualifying Object Names

  • Do not qualify objects with the database name. Datical takes care of that.
  • For a Single-Schema project, you do not have to qualify object names with the schema name. If not qualified, Datical uses the default schema for the user (dbo is the default).
  • For a Multi-Schema project, you must qualify object names with the schema name so they get deployed to the correct schema during packaging.
  • For a Multi-Database project,  you must qualify object names with the schema name so they get deployed to the correct schema during packaging. You typically organized folders by database and schema. You may also use only the database folder level. See /wiki/spaces/DDOC59/pages/795837068

SQL Server SCM Packaging Patterns

Note that Datical packages non-transient files differently from transient files. Place scripts for Oracle objects in packaging folders as follows. 

  • Non-transient - In-place editing, packaging and no archiving of database changes so they can be managed similar to application code. This applies to the following object types:
    • Procedures (when scripts are placed in the procedure folder)
    • Functions (when scripts are placed in the function folder)
    • Views (when scripts are placed in the view folder)
    • Triggers (when scripts are placed in the trigger folder)
  • Transient - Database changes are archived after packaging (all other folders).

Objects and Packaging Folders

Use the specified folder for listed SQL Server database operations. 

Operation and Object TypePackaging FolderArchived
CREATE/ALTER/DROP DATABASE LINKsql_directYes
CREATE/ALTER/DROP FUNCTIONfunctionNo
CREATE/ALTER/DROP INDEXddl, sql_directYes
CREATE/ALTER/DROP PROCEDUREprocedureNo
CREATE/ALTER/DROP QUEUEsql_directYes
CREATE/ALTER/DROP SEQUENCEddlsql_directYes
CREATE/ALTER/DROP SYNONYMddlsql_directYes

CREATE/ALTER/DROP TABLE

ddlsql_directYes
CREATE/ALTER/DROP TRIGGER

trigger

No
CREATE/ALTER/DROP TYPEsql_directYes
CREATE/ALTER/DROP VIEW

view

No
CREATE/ALTER/DROP VIEW INDEXddlsql_directYes
RENAME <DB_OBJECT>sql_directYes
OperationPackaging FolderArchived
INSERT, UPDATE, DELETE, SELECTdata_dmlYes
GRANT, REVOKEsql_directYes

Error Handling

Do not put error-handling statements in the SQL scripts. 

For SQL Server databases, do not include IF EXISTS statements with an object definition. 

Datical DB has its own error-handling that wraps SQL scripts. Specifying error-handling within the statements is not necessary.

Deployment Packager fails with an error if it encounters statements before an object definition.  


See also these pages for overview of packaging workflows, guidelines for writing scripts, and which packaging methods or folders to use for which types of changes:

Overview of Packaging

Writing SQL Scripts for Datical DB

Fixed Folder Names

Flexible Folder Names

  • No labels