Mushfique Khan
asked on
Unix scripting: need some help
Need to run sql scripts via unix/linux, against corresonding databases, basically updating some columns in different databases/schema & tables too, have all the update scripts ready, but rightnow they are all individual scripts, need to merge them all together as one shell script, in order for them to be executed as sys and globally too, basically just after the refresh job completed, they'll execute this one global scripts, which'll update all the columns in the corresponding databases/schemas & tables too.
Can any one please assist/advise/guide in writing this unix shell script, here is the req:
- should be only one script for all the databases/environments
- must be executed as sys, because can't code the password, will be kicked off by the job schedular, just after the refresh job finished.
- not all the columns are same in all the dbs, means the script need to check the databases running on this box/server and then only execute the script corresponding to that database/schema & tables only.
Also is there any way to commit in between too, because just executed one script and there is big spike on the db, means would like to commit too, in between, after some thousands of updates.
Can any one please assit/guide here ... thanks in advance.
Can any one please assist/advise/guide in writing this unix shell script, here is the req:
- should be only one script for all the databases/environments
- must be executed as sys, because can't code the password, will be kicked off by the job schedular, just after the refresh job finished.
- not all the columns are same in all the dbs, means the script need to check the databases running on this box/server and then only execute the script corresponding to that database/schema & tables only.
Also is there any way to commit in between too, because just executed one script and there is big spike on the db, means would like to commit too, in between, after some thousands of updates.
Can any one please assit/guide here ... thanks in advance.
ASKER CERTIFIED SOLUTION
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
Not sure exactly how this is working. I'm assuming that you are going to deploy one script on many machines. One large script to maintain.
If that is the case, I would put the commands for each database into a single if block. Then pass in the databases that are on the machine on the command line. That can be maintained in the job scheduler as databases don't move often.
Something like ....
Open in new window
That is a basic idea of how I would do it. You probably need to add more if there are multiple databases on a machine and maybe some error processing.