Order Purge
Order Purge
Order Purge
Introduction
Rosemount Inc. is a manufacturing company whose Measurement Division in Eden Prairie, Minnesota produces highly configured process instrumentation. The company had little experience with relational database and UNIX technology prior to implementing the suite of Oracle Applications. Rosemount installed Oracle Financials version 10.5 in December 1995 and Oracle Manufacturing and Order Entry version 10.5 in January 1997. Rosemount has bolted several applications solutions onto the Oracle Applications, some through third party vendors and some with the assistance of Oracle Services. These customizations added to the level of effort needed in the archiving process to ensure referential integrity, but they will be considered outside the scope of this paper. Any other companies contemplating an archive process must keep custom database objects in mind during the design of their process. There were two factors influencing Rosemounts decision to look at archiving: disk utilization growth projections and system response times. Storage rapidly became a concern when after five months of production activity, we had several million sales order lines in our production database. Like many companies, the production database is propagated to other databases used for development, testing, reporting, and recovery. The volume of data in a 50-60 gigabyte database would be too large to copy to other databases. Every row of data removed from production would mean five rows removed in total, once the space had been reclaimed through a database reorganization.
applications in the first place. Any archiving process must handle quotes (which are never closed) as well as fully processed production orders. The standard purge process in Oracle has been constructed to only handle closed orders. Finally, and most importantly, maintaining database referential integrity was the most important technical criteria in Rosemounts requirements gathering process. The user community also had several requirements, before granting their approval for data to be moved from the production database. First, the migrated data must be available to users in the production database. Also, some types of orders are needed in production for a relatively long period of time. As a result, users needed the ability to have orders ignored by the archiving process, whether individually identified or based on order type logic. Since quotes are often turned into actual orders, even well after the individual quote date, the user community needed the ability to perform order copies on previously archived quotes and orders. Finally, due to year-to-date reporting needs, data created in the current fiscal year must be maintained as a logical unit, no matter if the data resides on the production or archival database.
entry tables based on the records held in the SO_PURGE_ORDERS table. (See figure 1)
Orders in the Purge selection process may be selected based on any of the following criteria: Order category Order type Order number (range) Creation date (range) Order date (range) Customer Number of days closed However, not every order that meets the selection criteria will be purged. Each order is checked for several conditions before the SO_PURGE_ORDERS table is populated. The order must be closed. Also, there can be no open demand, open work orders, or open invoices for the order in question. Also, no open returns can exist for the order. Closed orders that pass all these criteria are passed to the SO_PURGE_ORDERS table. The user must then run the concurrent program for the Order Purge. The purge program is a package of stored database procedures and functions that process a cursor to retrieve the HEADER_ID from the SO_PURGE_ORDERS table, and then run through the following OE tables to see what data is tied to the header that is going to be removed. All of the data is removed as a logical group to preserve referential integrity. The tables purged by the Oracle Order Entry purge process include (listed alphabetically): SO_EXCEPTIONS SO_FREIGHT_CHARGES SO_HEADERS SO_HOLD_RELEASES SO_HOLD_SOURCES SO_LINE_APPROVALS SO_LINE_DETAILS SO_LINE_SERVICE_DETAILS SO_LINES SO_NOTE_REFERENCES
SO_ORDER_APPROVALS SO_ORDER_CANCELLATIONS SO_ORDER_HOLDS SO_PICKING_BATCHES SO_PICKING_CANCELLATIONS SO_PICKING_HEADERS SO_PICKING_LINE_DETAILS SO_PICKING_LINES SO_PICKING_RULES SO_PRICE_ADJUSTMENTS SO_SALES_CREDITS
archiving in the production database is that any copy of production made also brings across the archive data to the new database. Generating a test propagates test archive tables and a reporting database would have a reporting copy of the archive tables. This could be beneficial in certain environments. As a final general comment, Oracles standard purge processing is set up as two concurrent manager programs with no logic to link the two processes. Archiving at Rosemount was developed as two concurrent manager sets, one for orders and one for quote orders. The use of sets improves the control of the purge process, since archiving introduces job dependencies that must be more rigorously monitored. The key point is that any errors in the archive process will cause the concurrent program set to fail, which in turn stops the final purge step from processing.
Obviously, the key to archiving any of the order entry data involves processing the data in the SO_PURGE_ORDERS table before the data is removed in the Order Purge program. Now that the purge process has been reviewed, we can discuss how archiving can be incorporated into the standard Oracle process.
Figure 2
While Rosemount put the data into a separate database because of our requirements, a compelling case can be made for either method. The advantage of keeping
needs to keep their custom objects in mind during a design creation. Here are some recommendations for the insert process. First, since columns could be added to the Order Entry tables in later software versions, I highly recommend that the individual column names be listed in the INSERT INTO ... SELECT statement. Also, columns that are defined as LONG datatypes need special processing, since they cannot just be listed in the INSERT INTO...SELECT statement. Third, the inserting is done based on a cursor against the SO_PURGE_ORDERS table. A commit is recommended after each header id in that table has been processed to keep all records for that HEADER_ID together as a logical unit of work. Commits will also help keep the rollback segments from filling up during the archiving process. The Production/Archive compare step does a record count for each Order Entry table based on the SO_PURGE_ORDERS table, to make sure every record that was in production is included in the archive. If the totals are different, the concurrent manager set processing is terminated. In the compare step, the SO_HOLD_SOURCES and SO_HOLD_RELEASES tables are not counted, since it is possible for rows on these tables to be tied to more than one order (one order could still be in production and the other is moved to archive). In the previous INSERT step, logic was added to these two tables to ignore DUPLICATE RECORD errors. Additionally, these two tables are ignored in the Purge Step. Finally, the purge process was altered at Rosemount, but only because we have the custom tables that are referentially tied to the SO_LINES table.
design is that creation of a testing archive database, or moving the archived data from one database to another simply requires the movement of the data and the modifications of the public synonyms. None of the other code discussed in this section needs to be changed at all. An example of a naming convention for the synonym would be to reference so_lines@ARCHIVE as SO_LINES_CUSTARCH. Once the synonyms have been created, views are created for every table that will be archive/purged. An example of a naming convention for the views would be to have the view for sales order lines data labeled CUSTOE.SO_LINES_CUSTALL. These views are owned by the CUSTOE schema and are created as a SELECT * from production UNION ALL SELECT * from the archive database public synonym. If desired, the multi-org ORG_ID logic can be incorporated into these custom views, just as the APPS views are created. It was critical for our reporting that the data be available for the users as a whole, instead of as two independent databases. Since we intended to use close date for our selection process, we had to handle situations where two orders were created on the same day, but closed in widely different time periods. Many of our reports summarize or group information by factors other than date closed. Use of the synonyms and the views means that a user does not need to know where the data resides. From their perspective, all of the data is accessible from production. The use of synonyms gives the DBA staff the flexibility to move the location of the data without requiring the user to change their forms or reporting. Basically, designing the archive process in this manner sets up three rules for data access. To see the production data, the developer or user access the tables (or APPS views in 10.7) as is currently done. To access archive data only, such as in Order copy processing, the public synonyms _CUSTARCH are referenced. Finally, to see data for both databases together, the views owned by the CUSTOE user are referenced. Creation of the VIEWS handles reporting needs, but additional programming was necessary to allow for inquiry and copy functions from within the Oracle Applications. Copies of the standard Oracle order copy and order inquiry forms (and stored procedures) were created. These forms are accessible under a new menu option for any user responsibilities that needed to have access to Navigation ==> Archive ==> Orders. Due to the
number of forms that are accessed in Order Inquiry processing, the following is a list of forms that must be copied and modified to have an Archive version of the forms: OEXOECOR - order copy OEXOETOP - order inquiry Also, the following are all called from OEXOETOP OEXOEOIN - invoice inquiry OEXOEOSI - view cycle status OEXOEOII - view order and return status OEXOESPB - view shipping status OEXOERMA - order entry RMA form OEXOEMOE - order entry form Some people may ask why the design encourages the creation of a second form, instead of the modification of the standard Oracle form to use the views that show the combined information. The key reasons are that modifications of the standard forms would jeopardize our ability to receive Oracle support and would make installation of patches more complex. Also, a combined form would leave the organization in a high risk position if problems with the archive database or with SQL*NET ever made the archive data inaccessible. In the current design, unavailability of archive data does not prevent the user from performing standard production activity.
standard Oracle Purge procedures are not yet installed in your organization, the SO_PURGE_ORDERS table and concurrent job create scripts oecretab.sql and oeorcatv.sql must be run. Grants must be run against the production tables, to ensure that the CUSTOE user has access to read and delete from the production tables. Once this is completed, the public synonyms and views for archiving can be created. At some point, the concurrent manager programs and executables must be created for the following stored procedures: Order archive selection (Standard or Custom) Custom quote archive selection Archive orders Compare orders Purge Orders (Standard or Custom) Additionally, the quote and order archiving report sets must be created. Make sure that all programs and sets are made incompatible with each other. Making the sets alone incompatible is insufficient, since error correction may force the rerunning of steps outside the sets. Finally, the PL/SQL code to install the database package of archiving procedures must be installed under the CUSTOE database owner. Grants must be performed against these procedures, so that OE (in 10.5) or APPS (in 10.7) have access to the new code. Additionally, the modified forms must be registered to the Oracle Applications and menu options must be added to make forms accessible. Any user responsibilities that need access to the new screens must have their menu options modified to include the new archive menu option.
Implementation Steps
Now that the different design issues of Order Entry archiving have been discussed, here are the implementation steps that were followed to install archiving in Rosemount. The key is to make sure that all of the steps have been completed to create a fully functional archive process. The sequencing of the tasks is less critical for several of the steps. After this section, the lessons learned during this process will be reviewed. The first technical objects that must be created in archiving are the tables that will be the recipients of the production data. Also, if a table is used to hold the record counts from the compare step, that table must be created in the production instance. Make sure that critical indexes from the production environment, such as indexes based on HEADER_ID, are added to the new tables. Also, grants on these tables must be created, to allow the later creation of the public synonyms and reporting views. Next, since the modified forms will be owned by the database schema CUSTOE, messages used in the order copy and inquiry forms must be added to the message files for CUSTOE in the application. Also, if the
in the Selection step are less of an issue, since no data has been moved or deleted at this stage of processing. Second, make sure that business processes are fully understood. If your organization allows returns up to a year after shipment, there may be issues if you archive orders before the end of that year. The OEXOERMA form cannot process returns if the original order is no longer on the production database. Also, if archiving of quotes is desired, make sure that the life span of various types of quotes is fully understood. Additionally, since Order Entry is a widely used module within Oracle, special pains should be taken to ensure that the user community understands the standard timetable for archiving orders and how to access these orders. In any organization, some thought should be given as to whether a reverse archive process is needed, primarily to limit the risk of archiving data that is later identified as necessary. This process would take SELECTED orders out of the archive database and would put them back in the production database. As a reminder, if a process like this is created, make sure that any insert or update triggers on the Order Entry tables have been disabled, or they will fire when the data is reinserted into production. A great deal of testing is necessary to ensure that the performance of the views is acceptable to the organization. Some performance issues can be resolved by including more of the production indexes against the archive table, if EXPLAIN PLANS show that full table scans are being performed by the Oracle optimizer. Additionally, we are still investigating performance issues related to queries that involve local and remote database joins in the same select statement. The failure condition is that the remote table access converts to a full table scan, even though the appropriate indexes exist. Hints have helped in certain queries, but the issue is not completely understood at this point. Available documentation indicates that Oracle database version 7.3 should handle this situation, but that is not Rosemounts current experience. As of the writing of this paper, an open TAR is still outstanding within Oracle Support.
completed in order to migrate Order Entry archiving from an earlier version of the applications to 10.7. First, if archiving has been implemented using a separate archiving database (but keeping the standard Oracle table names), the table names in the archive database instance must be changed to match the 10.7 instance names. For example, SO_LINES must be changed to SO_LINES_ALL, similar to what is occurring in the AUTOINSTALL conversion process. Second, an organization implementing a multi-org environment (which Rosemount is doing) needs to create scripts to populate the ORG_ID field with the value of the operating unit. This is done automatically for the production database when the ADADMIN utility is run to create the multi-org environment, but the Oracle process will not populate the custom archive tables. Third, in the custom archiving views, the table names in the UNION statements must be changed to match the new Oracle _ALL names that are present in the 10.7 database. Fourth, a review must be made of the standard Oracle tables to see if columns have been added to the tables that will be archived. Any table alterations must be duplicated in the archive tables and also must be addressed in the INSERT scripts in the Copy to Archive step.
Final Comments
One question remains: Was Order Entry Archiving a success at Rosemount. While the final jury is still out, the answer is yes, but not an unqualified success. The growth rate of disk utilization has flattened out on our production systems. Additionally, performance in order entry on-line and reporting tasks has improved. The amount of the improvement is difficult to quantify, since CPU and other hardware changes have also been made to our production environment, making an applesto-apples comparison extremely difficult. Also, there is not immediate feedback on space savings, since these savings are not fully realized until a database reorganization has been completed. The inquiry and copy processing steps are working as designed. The users have the required visibility to the archived data. However, due to the unresolved performance issues discussed in the technical lessons learned, reporting still provides opportunities for
Upgrade Issues
A key factor in any modification of Oracle Applications is how product upgrades will affect the implemented changes. The author has had an opportunity to review Oracle version 10.7, and below are tasks that must be
improvement. If these remain unresolved, we may have better success changing our architecture from the separate database approach to the archive tables within the production database approach. This would eliminate the local-remote query problems we are having. If the performance issues are then resolved at a later date, the data could again be moved to a separate database. Additionally, I was somewhat aggressive in moving data to the archive database. There have been instances where returns were accepted by the organization after the original order had already been archived. This situation required special process. There is no such thing as understanding the business processes too well. In many organizations, a great deal of reports will have to be changed to support the use of the custom archiving views. In the final analysis, each company must weigh the cost of code changes and increased code maintenance responsibilities against any storage and database performance issues they are experiencing.