** Notes: Run these installations as Admin user.
 For details of installation and migration, follow WebSphere Commerce V75 Info Center, section of “Installing and upgrading”, http://publib.boulder.ibm.com/infocenter/radhelp/v7r5/index.jsp.
1. Installation 
            The installation paths used in this sample:
                        RAD75                                     D:\RAD75\SDP
                        WAS7                           D:\RAD75\SDP\runtimes\base_v7
                        WCS developer:             D:\WCDE70
                        DB2                              D:\IBM\SQLLIB
                        IBM Installation Manager: D:\IBM\InstallationManager
            1.1 Install IBM Installation Manager and RAD7.5
                        At RAD7.5 installation setup package, by using the launchpad program, IBM Installation Manager automatically starts even if it is not already installed. 
                        You will then install Installation Manager on your computer during the process of installing Rational Application Developer.
                        * Follow carefully on this page for the details of installation : Installing Rational Application Developer or Rational Software Architect, http://publib.boulder.ibm.com/infocenter/wchelp/v7r0m0/index.jsp?topic=/com.ibm.commerce.install.doc/tasks/tiginstallrad.htm
            1.2 Follow the instructions to apply fixes to WAS70 and RAD75.
            1.3 Install WebSphere Commerce toolkit
                        Use Installation Manager to install the toolkit, following this link:               http://publib.boulder.ibm.com/infocenter/wchelp/v7r0m0/index.jsp?topic=/com.ibm.commerce.install.doc/tasks/tigdevtoolkit_gui.htm
            1.4 Install WCS feature pack
                        Follow this link :
            1.5 Install database DB2 V9.7
                        See details from DB2 V9 documentation.
                        This should be fairly simple installation, just follow the instructions of the installer.
2. Backup 
            Backup the installed WCS toolkit files, in case of later steps fail.
3. Restore Database from 561
            Run database backup from existing database. (Use name MALL for example)
                        > db2 backup db MALL
            Copy the file over to the target (this workstation) location.
            Run database restore 
                        > db2 restore db MALL
4. Prepare migration
            4.1 Export extension logic jar
                        Export existing extension logic jar.
            4.2 Export extension data jar
                        Export existing extension data jar as EJB jar.
            4.3 Export WARs
                        Export as JAR (not WAR).
                        # To export a custom Web project from WebSphere Commerce Developer Version 5.6.1, or a custom Java project from version 5.6.1 or version 6.0:
              4.3.1. Open your WebSphere Commerce Developer development environment workspace and open the J2EE perspective.
               4.3.2. Select the project containing your customized code. Right-click the mouse button and select Export .
               4.3.3. Select Jar file and click Next .
               4.3.4. In the list of resources under Select the resources to export , ensure your project is selected.
               4.3.5. Ensure Export generated class files and resources and Export java source files and resources are selected.
               4.3.6. Click Browse and choose a path to save the exported JAR file.
               4.3.7. Ensure Compress the contents of the JAR file is checked.
               4.3.8. Click Finish to complete the exporting,
                        # If you exported custom projects from a WebSphere Application Server Version 5.1 environment, you need to correct the paths in your compressed JAR or ZIP file. The directory path has changed from:
                                    * Stores/Web Content/storename
                                    to
                                    * Stores/WebContent/storename
5. Migration from V561 
            These steps may be different depends on the restored database data variation.
            ** For details of migration steps, please see http://publib.boulder.ibm.com/infocenter/wchelp/v7r0m0/index.jsp?topic=/com.ibm.commerce.install.doc/tasks/tmgwcdev.htm
            5.1 Migration of Logic jar:
                        Import:
                                    right click on WebSphereCommerceServerExtensionsLogic/src,
                                    import,
                                    select General/Archive file,
                                    browse to the logic jar that was exported from WCS561 as archive jar file.
                                    select the files that need to import. some of the files need to be excluded. (choose "com" only)
                                                .classpath
                                                .classpath.template
                                                .project
                                                .externalToolBuilders
                                                .svn
                                                META-INF
                                    Check overwirte existing files without warning.
Re-import/organize the lib jars:
                                    * Do #5.2 first to complete the data jar's migration
                                    * Import the jars from lib/ext, and jars from WC project.  (Should follow #5.2's approach to create user library of lib/ext jars, and WC jars. ) 
            5.2 Migration of Data jar.
                        Import: 
                                    Delete existing WebSphereCommerceServerExtensionsData. Check "Delete project contents on disk"
                                    select File\import\EJB\EJB JAR file
                                    select exported jar, 
                                    make sure the EJB project name is correct.
                                    check Add roject to an EAR, and make sure WC is selected at EAR Project Name.
                                    Refresh EJB project.
                                    (Update the class path for each custom project to resolve the dependencies on libraries and between projects)
                                    Properties/buildPath/Libraries/Add Library...
                                    select User Library, next, click UserLibraries..., click New..., enter name WCSEJBs (can be any name).
                                    Select this library, click Add JARs, browser to  wc.modules\ejbs\db2, select All (CTRL+A).
                                    click OK, Finish.
                                    Optimistic locking update:
                                    To use WebSphere Commerce optimistic locking, CMP 1.x EJB entity beans must extend from the ECEntityBean class. 
                                    If the EJB entity bean class defines an ejbLoad method, that method must call super.ejbLoad. 
                                    If it defines an ejbStore method, that method must call super.ejbStore. 
                           5.2.1. Open WebSphere Commerce Developer.
                           5.2.2. Optional: Validating that CMP entity beans can use optimistic locking
                           5.2.3. Expand the EJB Project that you want to migrate.
                           5.2.4. For each ejbCreate method in each class in the project:
 5.2.4.1. Add this.initializeFields(); as the first line in the method.
                                                 5.2.4.2. Add this.initializeOptCounter( primaryKey); as the last line in the method before the return statement, where primaryKey is the key generated by the key class. This method must be called after the primary key is set.
                                                            The resulting method should look similar to the following example, in which memberId is the primary key:
                                                            public com.ibm.commerce.extension.objects.BonusKey ejbCreate( java.lang.Long memberId,java.lang.Integer bonusPoint) 
                                                            throws javax.ejb.CreateException
                                                            {     
                                                                         this.initializeFields();
                                                                         _initLinks();
                                                                         this.memberId=memberId;
                                                                         this.bonusPoint=bonusPoint;
                                                                         BonusKey myNewBonusKey = new BonusKey (memberId);
                                                                         this.initializeOptCounter(myNewBonusKey);
                                                                         return null; }
                           5.2.5. Right-click the EJB Project that you want to migrate.
                           5.2.6. Select Migrate to WC optimistic locking.
                           5.2.7. When the migration is complete, click Details. A report of the files migrated displays. Check to see which files were changed, and whether any errors were found. If you need to store the migration results, you can select the results, right-click and select Copy and paste it into a text editor before clicking OK.
                           5.2.8. Remember to re-deploy the EJB project for the changes to take effect.
            5.3 Migration WARs, use Stores for example  
                           5.3.1. Open your WebSphere Commerce Developer Version 7.0 development environment workspace and open the Java EE perspective.
                           5.3.2. Select the corresponding project.
                           5.3.3. Right-click the target project and click Import .
                           5.3.4. Select the type of source that will be imported and click Next .
                           5.3.5. Click Browse to find the file you want to import.
                           5.3.6. If you are asked to overwrite any files, select Yes for each file.
                           5.3.7. Click Finish .
                                      Notes:
                                                 5.3.7.1. The class path for each custom project must be updated to resolve the dependencies on libraries and between projects.
                                                 5.3.7.2. Do not import any of the meta data, or your migration will not work. Meta data includes the following files:
                                                                        * .compatibility
                                                                        * .j2ee
                                                                        * .runtime
                                                                        * .project
                                                                        * .classpath
                                                                        * .websettings
                                                                        * META-INF/
                                                                                      o MANIFEST.MF
                                                                        * WebContent/WEB-INF
                                                                                      o base.tld
                                                                                      o flow.tld
                                                                                      o struts-bean.tld
                                                                                      o struts-html.tld
                                                                                      o struts-logic.tld
                                                                                      o struts-nested.tld
                                                                                      o struts-template.tld
                                                                                      o struts-tiles.tld
                                                                                      o ibm-web-bnd.xml
                                                                                      o ibm-web-ext.xml
                                                                                      o WCEP.tld
                                                                                      o web.xml
                                                                                      o struts-config-catalog-services.xml
                                                                                      o struts-config-contract-services.xml
                                                                                      o struts-config-GiftCenter.xml
                                                                                      o struts-config-management-center.xml
                                                                                      o struts-config-marketing-services.xml
                                                                                      o struts-config-member-services.xml
                                                                                      o struts-config-order-services.xml
                                                                                      o struts-config.xml
                                                                                      o struts-wc-webservices.xml
                                                                        * WebContent/META-INF/
                                                                                      o MANIFEST.MF
                                                                        * WebContent/WEB-INF/lib
                                                                                      o wcbase.jar
                                    5.3.8
                                                # Search for the 
                                                For example:
                                                # After you have migrated the JSP files, in order to get all of your store pages to work, you must do the following steps:
                                       5.3.8.1. Navigate to the following directory on your WebSphere Commerce Version 5.6.1 or 6.0 machine:
                                                              * WCDE_installdir\properties\tools\stores\store_name
                                       5.3.8.2. Copy the directory and paste it into the WebSphere Commerce Version 7.0 directory:
                                                              * workspace_dir\WC\properties\tools\stores\store_name
                                       5.3.8.3. Version 5.6 Navigate to the following directory on your WebSphere Commerce Version 5.6.1 machine:
                                                              * workspace_dir\Stores\Web Content\WEB-INF\classes\store_name
                                       5.3.8.4. Version 5.6 Copy the directory and paste it into the WebSphere Commerce Version 7.0 directory:
                                                              * workspace_dir\stores\src\store_name
                                       5.3.8.5. Refresh your workspace.
            5.4 Migrate database
            Follow the instruction on info center.
            If the migration wizard fails, use command line. (I have error of parsing the config.xml through wizard, below are steps for command line migration).
            Assuming the restore database is completed.
            These are basic steps, if you donot run into any trouble.
                           5.4.1.0 Go to directory WCDE_installdir\bin.
                           5.4.1.1 Run the updatedb2configuration.bat script. 
                           5.4.1.2. Run the database check script by typing:
                                      wcim_ant.bat -tier db -action check -from 561                            
                           5.4.1.3. Run the database migration script by typing:
                                      wcim_ant.bat -tier db -action migrate -from 561 
                           5.4.1.4. Check the wcim.server.yyyy.mm.dd_hh.mm.ss.log file in the WCDE_installdir\logs\WCIM\ directory (assuming you are using the defaults) for additional messages or errors. Resolve any errors that are flagged before proceeding. To check the log files, complete the following steps:
                                                 1. Access the log file by typing the following path:
                                                                        * Windows WC_installdir\logs\WCIM\wcim.server.yyyy.mm.dd_hh.mm.ss.log
                                                 2. Review warnings generated by the database tier migration script and determine if any actions are needed based on those warnings. The actions can be found within the warning. The following list shows the type of warnings to review:
                                                            [2009.09.23.23.07.23] WARNING: [wcimBootstrapDeltaTask] The bootstrap data has changed. Consider replacing data in table cmdreg with data in cmdreg_new.
                                                            [2009.09.23.23.07.23] WARNING: [wcimBootstrapDeltaTask] The row in thecmdreg_new: storeent_id = 0, interfacename = 0, classname = com.ibm.commerce.usermanagement.commands.UserRegistrationAddCmd, properties = com.ibm.commerce.usermanagement.commands.UserRegistrationAddUBFCmdImpl
                                                            [2009.09.23.23.07.23] WARNING: [wcimBootstrapDeltaTask] The row in thecmdreg : storeent_id = 0, interfacename = 0, classname = null, properties = com.ibm.commerce.usermanagement.commands.UserRegistrationAddCmdImpl
                                                            [2009.09.23.23.07.23] WARNING: [wcimBootstrapDeltaTask] The row in thecmdreg_new: storeent_id = 0, interfacename = 0, classname = com.ibm.commerce.order.calculation.ApplyShippingCmd, properties = com.ibm.commerce.order.calculation.ApplyShippingCmdImpl
                                                            [2009.09.23.23.07.23] WARNING: [wcimBootstrapDeltaTask] The row in thecmdreg : storeent_id = 0, interfacename = 0, classname = null, properties = com.ibm.commerce.order.calculation.PromotionEngineApplyShippingCmdImpl
            ***  5.4.2 In the sample database I have taken, there are issues, so these are the steps to fix: 
5.4.2.1 if the process fail, check file D:\WCDE70\migration\xml\features\BASE\db\561\build.xml,
                        comment out those comepleted steps so the process can be resumed.
                        otherwise, the database needs to be restored.
                        5.4.2.2 Issue: there are some categories do not have association in storecgrp.
                                    Run this to fix data issue:
                                    insert into storecgrp select 10051,CATGROUP_ID from catgroup where catgroup_id not in (select catgroup_id from storecgrp) and catgroup_id<>0
                                                drop trigger MY_TRIGGER;
....
....
                                    --db2 -tvf D:\WCDE70\schema\migration\561\db2\wcgrm.sql
                                    run part of wcgrm.sql:
                                                DROP INDEX GR_index1;
                                                                DROP INDEX GR_index2;
                                                                DROP INDEX GR_index3;
                                                                DROP INDEX GrG_Constraint1;
                                                                DROP INDEX GrR_Constraint3;
                                                                --DROP INDEX GrE_Constraint3;
                                                                DROP INDEX PR_index_1;
                                                                DROP INDEX GiftItem_index2;
                                                                DROP INDEX GiftItem_uindex1;d
                                                                DROP INDEX GiftItem_index1;
                                                                DROP INDEX GrETDesc_uindex1;
                                                                DROP INDEX GrAddr_index2;
                                    in D:\WCDE70\schema\db2\fixpack1\wcs.giftRegistry.sql comment out :
                                    -- INDEX gr_index2 
                                    --DROP INDEX gr_index3 
                                    Log output sample:
                                                INFO:   INDEX16K=TAB16K
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/promotions/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/dd/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/jstl/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/BASE/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/config/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/struts/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/coremetrics/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/GiftCenter/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/wmm/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/dynacache/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/web-bnd/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] D:\WCDE70\migration\xml\features/commonJ/db/561/build.xml
                                                INFO:   [wcimListFeaturesTask] 'BASE','promotions','struts','GiftCenter'
                                                INFO:   [wcimCallTargetTask] feature: 'BASE'
                                                INFO:   [wcimDBVersionInfoTask] SET SCHEMA DB2ADMIN
                                                INFO:   [wcimDBVersionInfoTask] SELECT * FROM SITE
                                                INFO:   [wcimDBVersionInfoTask] Columns in the SITE table:
                                                INFO:   [wcimDBVersionInfoTask] COMPNAME=null
                                                INFO:   [wcimDBVersionInfoTask] EDITION=be
                                                INFO:   [wcimDBVersionInfoTask] VERSION=5
                                                INFO:   [wcimDBVersionInfoTask] RELEASE=6
                                                INFO:   [wcimDBVersionInfoTask] MOD=1
                                                INFO:   [wcimDBVersionInfoTask] FIXPACK=-1
                                                INFO:   [wcimDBVersionInfoTask] Properties in memory:
                                                INFO:   [wcimDBVersionInfoTask] editionKey=be
                                                INFO:   [wcimDBVersionInfoTask] ecVersionKey=5
                                                INFO:   [wcimDBVersionInfoTask] releaseKey=6
                                                INFO:   [wcimDBVersionInfoTask] modificationKey=1
                                                INFO:   [wcimDBVersionInfoTask] fixpackKey=-1
                                                INFO:   [wcimDBCheckingTask] SET SCHEMA DB2ADMIN
                                                INFO:   [wcimDBCheckingTask] select count(*) from BUSAUDIT
                                                INFO:   [wcimDBCheckingTask] select count(*) from CACHEIVL
                                                INFO:   [wcimDBCheckingTask] select count(*) from CATENCALCD
                                                INFO:   [wcimDBCheckingTask] select count(*) from CATGPCALCD
                                                INFO:   [wcimDBCheckingTask] select count(*) from EMLMSG
                                                INFO:   [wcimDBCheckingTask] select count(*) from ICMREGDESC
                                                INFO:   [wcimDBCheckingTask] select count(*) from ORDERS
                                                INFO:   [wcimDBCheckingTask] select count(*) from ORGENTITY
                                                INFO:   [wcimDBCheckingTask] select count(*) from PX_PROMOTION
                                                INFO:   [wcimDBCheckingTask] select count(*) from REFKEYS
                                                INFO:   [wcimDBCheckingTask] select count(*) from STOREENTDS
                                                WARNING:        [wcimDBCheckingTask] In order to migrate one of the biggest tables "ORDERS" in the database, the database migration script needs at least 45   MB in the database log space. Requires at least 45 MB free dis
                                                INFO:   [wcimDBCheckingTask] select count(*) from address where status='P' and selfaddress=1 and member_id=-1000 and isprimary=1
                                                INFO:   [wcimDBCheckingTask] select count(*) from address where status='P' and selfaddress=1 and member_id=-2001 and isprimary=1
                                                INFO:   [wcimDBCheckingTask] select count(*) from address where status='P' and selfaddress=1 and member_id=-2000 and isprimary=1
                                                INFO:   [wcimDBCheckingTask] select count(catgroup_id) from catgroup where catgroup_id not in (select catgroup_id from storecgrp) and catgroup_id<>0
                                                INFO:   [wcimCallTargetTask] feature: 'promotions'
                                                INFO:   [wcimCallTargetTask] feature: 'struts'
                                                INFO:   [wcimCallTargetTask] feature: 'GiftCenter'
                                                INFO:   [wcimEchoTask] Finishing ANT for WCIM at February 23 2011 12:21 PM.
                                                INFO:   WCIM has completed the job(s) successfully.
                        5.4.3 Customized data migration
                                    Add OptCounter to customized tables:
                                    ALTER TABLE table_name ADD COLUMN optcounter SMALLINT
 。。。。
                                    create trigger.
                                    db2 -td# -vf trigger.sql
                                    below is the sql contents:
                                    // ***** Starting of trigger.sql                                                     
                                                            CREATE TRIGGER perf_cma
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON EMAILREG  
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cm1
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON MOSTPOP 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cm2
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CATREQ 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cm3
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON PHONEREG 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cm4
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON POSTREG 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cm5
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON DATAEXPORTCONF 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cm6
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CATUPDATEERROR 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cmc
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CATUPDATE 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cm7
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CATUPDATEIMAGE 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cm8
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CATUPDATESKU 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cm9
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON IMAGEUPDATE 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a10
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CATUPDATEPACKAGE 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a11
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON HAMMERDROPSTATS 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a12
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON HAMMERDROPEVENT 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cmo
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON NEWMOVER 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cmp
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON HDROPSTATSBYHOUR 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a13
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON HDROPSTATSBYQTY 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a14
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON PRIVPREFACTION 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a15
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON INVSNAPSHOT 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a16
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CATENTEXT 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a17
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CPADDRLOOKUP 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a18
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CPSTREETREF 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_cmr
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON CPMUNICIPALITYREF 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a19
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON XCONTESTINFO 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a20
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON HDTOPSELLERS 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a21
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON PLANTTAG 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a22
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON PLANTTAGATTR 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a23
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON PLANTTAGATTRTXT 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a24
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON PLANTTAGITEM 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a25
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON WORKSHOP 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a26
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON WORKSHOPSIGNUP 
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                                                                                                        CREATE TRIGGER perf_a27
                                                                                                                                                 NO CASCADE BEFORE UPDATE ON HDSTORES  
                                                                                                                                                 REFERENCING NEW AS NEWOPT OLD AS OLDOPT
                                                                                                                                                 FOR EACH ROW MODE DB2SQL
                                                                                                                                                   when ((NEWOPT.optcounter is null) or (OLDOPT.optcounter = NEWOPT.optcounter))
                                                                                                                                                   begin atomic
                                                                                                                                                                                                   set NEWOPT.optcounter = case
                                                                                                                                                                                                                        when OLDOPT.optcounter < 32767
                                                                                                                                                                                                                        then
                                                                                                                                                                                                                                                 OLDOPT.optcounter + 1
                                                                                                                                                                                                                        else
                                                                                                                                                                                                                                                 1
                                                                                                                                                                                                                        end;       
                                                                                                                                                   end#
                                    //***** end of trigger.sql 
                        5.4.4 Continue with manual migration script. (Wizard does not work becuase of not able to parse config.xml )
                                    //wcim_ant.bat -tier db -action check -from 561
                                    wcim_ant.bat -tier db -action migrate -from 561
            5.5 Additional migration work
                        Issues:
                        5.5.1 object naming of Enumeration cannot be enum, as it is reversed keyword for Java1.5.
                        Repalce all from logic, jsps.
                        5.5.2 Migrating EJB will create backends folder under META-INF which creates the table names same as bean name.
                        This needs to  be corrected.
                        5.5.3 Web server setup
                        5.5.4 Libs
                                    Copy all library jars from Lib\ext\ over, but remove wcs.jar.
 
