Database Utility Tool: Transaction Code - SE14
When a table is created in SE11(ABAP Dictionary) upon activation of table definition, SQL statements are generated and sent to the RDBMS causing it to create an actual table in database. Database Utility Tool is an interface between the ABAP Dictionary and underlying relational database system (RDBMS). It is used to examine or modify tables at database level.
When a transparent table is altered (standard/custom), it is first adjusted via SE14 and then activated. What exactly happens at database level, how a table is adjusted, what happens to table contents,.... is what we are going to unleash in following section!
Table Activation and Adjustment:
When you adjust table via SE14. It offers two adjustment options - Delete Date and Keep Data.
Delete Data: Table is deleted in database and re-created with new definition. Data is lost.
Keep Data: ALTER TABLE is performed, if not possible then table conversion is triggered.
Say for instance we have changed a table(TAB) field's length from 50 to 25 then the steps performed to adjust database table (referred as TAB) with Keep Data option is as follows:
- Table (TAB) is locked. All the views that used table TAB are deleted
- TAB is renamed as QCMTAB in database
- TAB is activated in ABAP Dictionary with new definition. Activation of modified table TAB leads to creation of database table QCM8TAB in database with primary key but no data.
- Reload data - data copied from QCMTAB to QCM8TAB (with MOVE-CORRESPONDING statement). Database commit is stored after 16MB. If a field length is reduced then field contents are truncated.
- Delete QCMTAB table
- Rename QCMTAB to TAB. Secondary indexes are newly created and views deleted in Step 1 are re-created
- Remove Lock from TAB
No comments:
Post a Comment