Migrating from Compiere
Contents
Sample case - migrate a customer from Compiere 2.5.2d to Adempiere 3.1.4
Approach 1 - Apply scripts until migrated
Tools
- To generate diff between databases
- Karsten migration tool (needed) - free, born in Adempiere Bazaar - http://svn.sourceforge.net/viewvc/adempiere/branches/stable/migration/dist/
- TOAD (recommended) - non-free - http://www.toadsoft.com/toad_oracle.htm
- alternatively TOYS - non-free - http://www.impacttoys.com/
- To apply the scripts
- TOAD (recommended)
- alternatively SQL*Developer
- alternatively SQL*Plus
- or any of the thousand tools to execute sql scripts in oracle
Steps
The objective with this approach is to construct scripts to apply in the customer database until the target release is reached.
First step - Generate migration scripts from 252d to 253a
Currently there are tested migration scripts from 253a to 314, so first step will be to migrate customer from 252d to 253a.
- Create customer database
- Create Compiere seed from customer version (in the sample Compiere seed 2.5.2d)
- Create Compiere 253a seed
- Generate schema difference between 252d and 253a databases -> I used TOAD to generate file FromCompiere252dTo253a.sql
- Install Karsten migration tool - following steps mentioned in \trunk\migration\src\readme.txt
- Follow instructions on eclipse
- Change DBDifference.java
- private static final String DB1_NAME = "xe";
- private static final String DB1_URL -> point to my machine
- private static final String DB1_USER = "compiere252d";
- private static final String DB1_PASSWD -> my password
- private static final String DB2_NAME = "xe";
- private static final String DB2_URL -> point to my machine
- private static final String DB2_USER = "compiere253a";
- private static final String DB2_PASSWD -> my password
- private static final String AD_ROLE_ID = null;
- private static final String AD_CLIENT_ID = null;
- Run Karsten migration tool. Please take account that Karsten migration tool also generate the schema difference to be reviewed (I just use TOAD because I used lots of times and I trust very well the scripts generated with TOAD)
- With the output of migration tool save file migrationDictionary252dTo253a.sql
Now we have all the scripts to migrate to 314. Just we need to review carefully every script and analyze/solve the problems.
Second step - Apply scripts
We're ready to apply scripts, they must be applied in customer database in this order:
- FromCompiere252dTo253a.sql
- migrationDictionary252dTo253a.sql
- All scripts http://svn.sourceforge.net/viewvc/adempiere/trunk/migration/253a-253b/
- All scripts http://svn.sourceforge.net/viewvc/adempiere/trunk/migration/310-311/
- All scripts http://svn.sourceforge.net/viewvc/adempiere/trunk/migration/311-312/
- All scripts http://svn.sourceforge.net/viewvc/adempiere/trunk/migration/312-313/
- All scripts http://svn.sourceforge.net/viewvc/adempiere/trunk/migration/313-314/
and so on until the target release is reached
NOTE: Application of every script must be reviewed carefully to analyze/solve errors.
NOTE: You can use this tool to run all scripts in a directory - http://svn.sourceforge.net/viewvc/adempiere/trunk/migration/migrate.sh
Third step - Test with Adempiere 3.1.4
- Open Adempiere 3.1.4 against the migrated database
- Run Sequence Check
- Run Synchronize Terminology (if you use translations)
- Start testings
Approach 2 - Insert data in fresh installation
The first approach can be difficult because you have many scripts to review/apply. This approach is more straight, because the revision points are fewer.
Tools
- To generate diff between databases
- TOAD (recommended) - non-free - http://www.toadsoft.com/toad_oracle.htm
- alternatively TOYS - non-free - http://www.impacttoys.com/
- Karsten migration tool - free, born in Adempiere Bazaar - http://svn.sourceforge.net/viewvc/adempiere/trunk/migration/dist/
- To apply the scripts
- TOAD (recommended)
- alternatively SQL*Developer
- alternatively SQL*Plus
- or any of the thousand tools to execute sql scripts in oracle
Steps
First step - Generate migration scripts from 252d to customer
The first step is to generate a migration script from 252d (customer original seed) vs the customer database. This script is intended to be applied in fresh 314 database.
- Create customer database
- Create Compiere seed from customer version (in the sample Compiere seed 2.5.2d)
- Generate schema difference between 252d and customer databases -> I used TOAD to generate file 02_FromCompiere252dToSource.sql
- Karsten migration tool can be used too. Please take account that Karsten migration tool also generate the schema difference to be reviewed (I just use TOAD because I used lots of times and I trust very well the scripts generated with TOAD)
Second step - Generate insert script from customer source to target
You can find the support scripts here: http://svn.sourceforge.net/viewvc/adempiere/trunk/migration/tools_migrate_with_insert/
- Create target database - this is a fresh seed of a 314 installation
- You need to create first a directory -- CREATE OR REPLACE DIRECTORY dir_tmp AS '/tmp'
- And grant to target user permissions -- grant execute on utl_file to target
- Then create the procedure generate_insert_as (change dbsource and dbtarget)
- Run generate_insert_as - it generates file 04_InsertMigr.sql in the directory created
- Follow instructions in 01_pre_migrate
- i.e. most customers have pre-installed JasperReports, in this case you must add "AND columnname <> 'JasperReport'" to the where on ad_column and ad_element queries
- you must review cases where columnname is changed and edit properly the generated insert statement, i.e. table c_year changed the column year to fiscalyear, the insert as select for c_year must be properly changed to reflect this
- please review carefully columns reported in the script as -- columns in target, they must be reviewed if need to be filled and how to fill them
- please review carefully columns reported in the script as -- columns in source, they must be reviewed carefully, data can be lost, or maybe they could be renamed
Third step - Apply scripts
We're ready to apply scripts, they must be applied in target (fresh 314) database in this order:
- Apply 02_FromCompiere252dToSource.sql
- Apply 03_disconstraints.sql
- Apply generated and reviewed 04_InsertMigr.sql
- Apply 05_enaconstraints.sql
- Execute post_migrate tasks as outlined in 06_post_migrate.sql
Fourth step - Test with Adempiere 3.1.4
- Open Adempiere 3.1.4 against the migrated database
- Run Sequence Check
- Run Synchronize Terminology (if you use translations)
- Start testings