There are a lot of tools which allows us automate deployment process for databases.
Those tools could be divided into two big groups:
#1. Tools that uses general purpose language (Ruby, C#, Java, Python) for writing migration scripts.
#2. Tools that uses SQL language for writing migration scripts.
First group of tools gives for developers productive gain but leaves database administrator completely out of development process which is really bad idea.
Second set of tools requires a lot of additional work - every single change should be written as separate database patch. This slows down our work => make it more expensive.
Oblivious solution is to create the third set of tools... or at least just one which would be friendly to both DBAs and DEVs.
What about auditors? They should be happy too!
This document describes an XML database migration project that converts existing databases into XML file format. It discusses migrating from an existing single database conversion system to a new system that allows conversion of multiple database types like MS Access and SQL. The new system stores data in XML format as flat files for enhanced security, reduced memory usage and data access speed compared to the existing database system. It outlines the introduction, existing system, proposed improved system, module breakdown, software/hardware requirements and conclusion.
This document graphically demonstrates why database aliases should be used when migrating SQL databases. Aliases allow individual databases on the same SQL instance to be uniquely identified. By creating aliases that point to the same SQL instance but specify different databases, connections can be simplified to reference the alias instead of specifying the instance and database directly. This avoids issues that can occur when an alias only points to the instance without identifying a unique database.
This document describes an XML database migration project that converts existing databases into XML file format. It discusses migrating from an existing single database conversion system to a new system that allows conversion of multiple database types like MS Access and SQL. The new system stores data in XML format as flat files for enhanced security, reduced memory usage and data access speed compared to the existing database system. It outlines the introduction, existing system, proposed improved system, module breakdown, software/hardware requirements and conclusion.
This document graphically demonstrates why database aliases should be used when migrating SQL databases. Aliases allow individual databases on the same SQL instance to be uniquely identified. By creating aliases that point to the same SQL instance but specify different databases, connections can be simplified to reference the alias instead of specifying the instance and database directly. This avoids issues that can occur when an alias only points to the instance without identifying a unique database.
This document discusses techniques for continuous database migration. It introduces Carbon5, an open source database migration framework. Carbon5 works by having each schema change stored as a separate SQL script file. It tracks which changes have been applied to prevent duplicate executions. The document contrasts Maven-driven and embedded modes of using Carbon5. With Maven-driven, migrations run as Maven goals; with embedded, a bean handles migrations on application startup. Best practices discussed include feature-based script organization and avoiding direct database changes outside the framework. Alternatives like Flyway and NoSQL migration approaches are also briefly covered.
This document summarizes Phinx, a PHP database migration tool. It allows developers to programmatically update a database schema over time through migrations written in PHP. Key features include writing migrations, migrating up and down, seeding data, and supporting multiple databases like MySQL, PostgreSQL, and SQLite. The document provides installation instructions, best practices for writing migrations, and an overview of the tool's history and future plans.
This document discusses various database migration processes between different database systems. It provides step-by-step instructions for migrating databases from SQL Server 2014 to Oracle 11g, Oracle 11g to SQL Server 2014, SQL Server 2008R2 to MySQL, DB2 to Sybase SQL Anywhere 16, and PostgreSQL to SQL Server 2012. It also briefly discusses migrating between SQL Server 2008 and SQL Server 2012. Each migration process is followed by a verification section to check that the data was migrated correctly.
Database migration is the process of transferring data between different database systems or upgrades. It involves analyzing and mapping data from the source to the target system, transforming the data, validating data quality, and maintaining the migrated data. For example, Capital One migrated from Oracle to Teradata databases as their data volume grew too large for Oracle to efficiently handle. The migration process includes pre-migration planning, extraction, transformation, data loading, validation, and post-migration maintenance.
Tree-like data relationships are common, but working with trees in SQL usually requires awkward recursive queries. This talk describes alternative solutions in SQL, including:
- Adjacency List
- Path Enumeration
- Nested Sets
- Closure Table
Code examples will show using these designs in PHP, and offer guidelines for choosing one design over another.
Database-Migration and -Upgrade with Transportable TablespacesMarkus Flechtner
油
This document discusses using transportable tablespaces (TTS) to migrate a large telecommunications database from HP-UX to Linux with an Oracle upgrade. Key points:
- The customer has 4 databases totaling over 15TB that need to be migrated with downtime under 6 hours. TTS was chosen for the migration.
- Tuning efforts included resizing files, compression, and parallelizing file transfers and conversions across RAC nodes.
- Challenges included long metadata export times. The issue was addressed by splitting exports across multiple self-contained tablespace subsets in parallel.
- Automation scripts were created to coordinate the distributed migration work across RAC nodes.
15. RoundhousE db versioning tools
(part of the ChuckNorrisFramework)
Name: Chuck Norris
Email:
chucknorrisframework@googlegroups.co
m
Website:
http://groups.google.com/group/chucknor
risframework
Location: Chuck is everywhere
Project: https://github.com/chucknorris/
roundhouse
18. Running RoundhousE v0.8.0.305 against (local) - TestRoundhousE.
Looking in C:coderoundhousecode_dropsampledeployment..dbSQLServerTestRoundhousE for
scripts to run.
Please press enter when ready to kick...
==================================================
Setup, Backup, Create/Restore/Drop
==================================================
Creating TestRoundhousE database on (local) server if it doesn't exist.
==================================================
RoundhousE Structure
==================================================
Running database type specific tasks.
Creating RoundhousE schema if it doesn't exist.
Creating [Version] table if it doesn't exist.
Creating [ScriptsRun] table if it doesn't exist.
Creating [ScriptsRunErrors] table if it doesn't exist.
==================================================
Versioning
==================================================
Attempting to resolve version from
C:coderoundhousecode_dropsampledeployment_BuildInfo.xml using //buildInfo/version.
Found version 0.8.0.305 from C:coderoundhousecode_dropsampledeployment_BuildInfo.xml.
Migrating TestRoundhousE from version 0 to 0.8.0.305.
Versioning TestRoundhousE database with version 0.8.0.305 based on
http://roundhouse.googlecode.com/svn.
19. ==================================================
Migration Scripts
==================================================
Looking for Update scripts in
"C:coderoundhousecode_dropsampledeployment..dbSQLServerTestRoundhousEup". These
should be one time only scripts.
--------------------------------------------------
Running 0001_CreateTables.sql on (local) - TestRoundhousE.
Running 0001_CreateTables_NH.sql on (local) - TestRoundhousE.
Running 0002_ChangeTable.sql on (local) - TestRoundhousE.
Running 0003_TestBatchSplitter.sql on (local) - TestRoundhousE.
--------------------------------------------------
Looking for Run First After Update scripts in
"C:coderoundhousecode_dropsampledeployment..dbSQLServerTestRoundhousErunFirstAfte
rUp".
--------------------------------------------------
--------------------------------------------------
Looking for Function scripts in
"C:coderoundhousecode_dropsampledeployment..dbSQLServerTestRoundhousEfunctions".
--------------------------------------------------
Running ufn_GetDate.sql on (local) - TestRoundhousE.
--------------------------------------------------
Looking for View scripts in
"C:coderoundhousecode_dropsampledeployment..dbSQLServerTestRoundhousEviews".
--------------------------------------------------
Running vw_Dude.sql on (local) - TestRoundhousE.
--------------------------------------------------
20. Looking for Stored Procedure scripts in
"C:coderoundhousecode_dropsampledeployment..dbSQLServerTestRoundhousEsprocs".
--------------------------------------------------
Running usp_GetDate.sql on (local) - TestRoundhousE.
Running usp_SelectTimmy.sql on (local) - TestRoundhousE.
--------------------------------------------------
Looking for Run after Other Anytime Scripts scripts in
"C:coderoundhousecode_dropsampledeployment..dbSQLServerTestRoundhousErunAfterOt
herAnyTimeScripts".
--------------------------------------------------
Running createFiveItems.sql on (local) - TestRoundhousE.
--------------------------------------------------
Looking for Permission scripts in
"C:coderoundhousecode_dropsampledeployment..dbSQLServerTestRoundhousEpermissions
". These scripts will run every time.
--------------------------------------------------
Running 0001_AppRole.sql on (local) - TestRoundhousE.
Running 0002_AppReadOnlyRole.sql on (local) - TestRoundhousE.
Running 0003_AppPermissionsWiring.sql on (local) - TestRoundhousE.
LOCAL.GrantRobDataReaderDataWriterPermissions.ENV.sql is an environment file. We are in the
LOCAL environment. This will run based on this check.
Running LOCAL.GrantRobDataReaderDataWriterPermissions.ENV.sql on (local) - TestRoundhousE.
TEST.GrantRobDataReaderDataWriterPermissions.ENV.sql is an environment file. We are in the
LOCAL environment. This will NOT run based on this check.
Skipped TEST.GrantRobDataReaderDataWriterPermissions.ENV.sql - No changes were found to run.