Upgrading a Database Schema

Topic ContentsTopic Contents
  1. How to Update a Database Schema
    1. Backup Existing Database(s)
    2. Determine Current Database Schema
    3. Run Update Scripts
    4. Check Database Connection

CM4D Database schema upgrades should only be performed by a Corporate IT Professional, DBA or a CM4D user that very knowledgable about CM4D databases.

After upgrading a CM4D Installation, you may have databases from one or more schema versions back that you want to access. To access those databases, you need to migrate the databases to the latest schema version using the upgrade path(s) below.

Database scripts are included with each CM4D Enterprise installation, but you may also download them from our website.

Before you begin the upgrade process, you will need to answer the following questions:

Are you upgrading a Site Database?

Yes - Along with upgrading the CM4D Site database schema, you will also need to upgrade any CM4D DataSource databases that are managed by the CM4D Site database to the corresponding CM4D DataSource database Schema.

No - Upgrade your unmanaged CM4D DataSource databases to the correct CM4D DataSource database Schema.

What is the version of your current Database(s)?

Single-Schema Upgrades - If you are upgrading to the newest version of CM4D from the previous version of CM4D, you will only need to run the latest upgrade script(s) on your database(s).

Multiple-Schema Upgrades - If you are upgrading to the newest version of CM4D from a version older than one release, you will need to run all intermediate update scripts on your database(s) consecutively before updating to the latest Schema version. Refer to the Database Schema Reference for a list of versions and schema.

How to Update a Database Schema

The following steps are a general guideline for upgrading your database Schema.

Backup existing database(s)

Determine current database Schema

Run update scripts

Check database connection

Backup Existing Database(s)

Before executing any update scripts on your database(s), it is very important that you create a backup of your existing database(s). Once you have confirmed that the backup process was successful and complete, continue on to the next step.

You should always test an upgraded copy of your production database(s) in a test environment before upgrading your production databases to a new schema.

Determine Current Database Schema

All Schema upgrades must start with your current database Schema. If you do not know your current Schema, look at the SiteSchemaVersion and SchemaVersion Stored Procedures in your Database.

Run SQL Server Management Studio.

Expand Databases > YourDatabase > Programmability > Stored Procedures.

Find the stored procedure:

For a Site database - dbo.SiteSchemaVersion

For a CM4D database - dbo.SchemaVersion

Right-click on the stored procedure and select Modify.

Look for the string @version =

The Schema version will follow the equal sign in single quotes (e.g., '19a').

Do not make any changes to the stored procedure.

Exit SQL Server Management Studio.

Run Update Scripts

To upgrade the CM4D Schema version that is used by the new version of CM4D, you must run the appropriate Update scripts in sequential order. The update scripts will be provided along with the CM4D installation when you receive your upgrade.

Upgrading a SQL Server Database Schema

If you receive any errors while executing an update script, you must correct the issue(s) before continuing to the next script.

To see an example of upgrading a SQL database from Schema 14a to v19a, click herehere.

Example SQL Database Schema Upgrade

To upgrade the Site Schema version from v14 to v19, run the Update Site scripts on the Site database in the specified order:

Run UpdateSite15a.sql to upgrade the Site database Schema from 14a (v14.1) to 15a (v15.1).

Run UpdateSite16a.sql to upgrade the Site database Schema from 15a (v15.1) to 16a (v16.1).

Run UpdateSite17a.sql to upgrade the Site database Schema from 16a (v16.1) to 17a (v17.1).

Run UpdateSite18a.sql to upgrade the Site database Schema from 17a (v17.1) to 18a (v18.1).

Run UpdateSite19a.sql to upgrade the Site database Schema from 18a (v18.1) to 19a (v19.1).

Run Site Grant.sql to grant the Public role the appropriate privileges on the newly created objects in the Site Schema.

To upgrade the CM4D Schema version from v14 to v19, run the Update scripts on the CM4D database in the specified order:

Run Update15a.sql to upgrade the database Schema from 14a (v14.1) to 15a (v15.1).

Run Update16a.sql to upgrade the database Schema from 15a (v15.1) to 16a (v16.1).

Run Update17a.sql to upgrade the database Schema from 16a (v16.1) to 17a (v17.1).

Run Update18a.sql to upgrade the database Schema from 17a (v17.1) to 18a (v18.1).

Run Update19a.sql to upgrade the database Schema from 18a (v18.1) to 19a (v19.1).

Run Grant.sql to grant the Public role the appropriate privileges on the newly created objects in the CM4D Schema.

Refer to the topic Database Schema Reference to more information on upgrade paths and versions.

Site Schema Upgrade Path

Use the following upgrade path(s) to upgrade your Site Database(s). Starting with your current Site database Schema version, run each script sequentially until you reach the latest Schema version.

Refer to Site Database Upgrade Paths

CM4D DataSource Schema Upgrade Path

Use the following upgrade path(s) to upgrade your CM4D DataSource(s). Starting with your current CM4D DataSource database Schema version, run each script sequentially until you reach the latest Schema version.

Refer to CM4D Database Upgrade Paths

Check Database Connection

Once your database Schema has been upgraded, check that CM4D can connect to the database.

Run DbConnect.exe.

Click the Test Connection button.

If you have successfully connected to the database, your Schema upgrade is complete.

Can we improve this topic?