For a mandatory assignment of a DB2 class I’m asked to write o procedure to export “export information about all xxx, delete all xxx and import the information again.” where xxx is my table.
This procedure has to be as efficiently as possible.
I’m quite stuck here, quite naively I see two options
1) write a select * from xxx; drop …; insert; using python or something
2) using some export/import utility of db2
But I can be totally wrong, suggestions?
what I’ve noticed is that there are not integrity constraints.
You can do that via “export/load/set integrity“. I think it is the best way if you execute that in the server.
If you use python, you will have to use a odbc driver or similar to get the data, processes, etc.
If you use python just to execute the commands, it is ok, finally, it is just a call to the database.
If you execute the process in other machine, the net use is increased, and the performance is lower.
Using import, it is just like an “insert” per row in the file which uses a lot of transaction log. Instead, the load command, puts the data diretly in the tablespace and then check the referential integrity (faster process)
Finally, if you want to extract the information very fast, you can buy the IBM InfoSphere® Optim™ High Performance Unload for DB2 for Linux, UNIX and Windows