Need help on while loop


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Need help on while loop
# 1  
Old 01-23-2018
Need help on while loop

I am oracle devloper currently i get a chance to work on shell scripts to run sql statements.

extarct.txt contains 15 .sql files, want to using loop continue three times,first it should take 1 to 5 next 5 to 10 and last 10-15
I can't run all the .sql file in single run to avoid deadlock condition.

tried below code
Code:
#!/bin/sh 

cat extract.txt |while read name
do
sqlplus -s connect << EOF
userid/password@database
echo $name
exit
EOF
done

extact.txt

Code:
@1.sql
@2.sql
@3.sql
@4.sql
@5.sql
@6.sql
@7.sql
@8.sql
@9.sql
@10.sql
@11.sql
@12.sql
@13.sql
@14.sql
@15.sql

# 2  
Old 01-23-2018
Welcome to the forum.

Please become accustomed to supply info on your system / environment like OS, shell's, tools' versions.

We had a similar problem recently. What is your split version?
Do you want to run five scripts in parallel, or three, or all sequential?
# 3  
Old 01-23-2018
OS-IBM AIX
Yes i need to run the script five scripts in parallel
# 4  
Old 01-23-2018
So, I think you mean you want to run 1-5, then 6-10, then 11-15.

Can you use split to create 5 line input files? You can loop round the files you have generated and submit jobs in the background for each then wait for them all to complete. That is one way.

Another way might be to read the whole file as a single loop, but you might hit problems if your record count is not strictly divisible by 5.

Yet another way (but a logical change) would be to read the file in as a single loop and start 5 jobs. Then watch those jobs (get the background process id from $! just after it is launched) and when one finishes, start another. This way you will have 5 jobs running always rather than one long running job stopping all the others, but it depends if that's what you want your logic to do. It is a structural difference which may not be what you want.

Can you clarify what you want it to do?

I presume you are writing this in ksh or are you using bash or something else? This is usually considered better as a loop to prevent anything within the loop from reading (eating up) your input file data:-
Code:
while read name
do
   # whatever
done < extract.txt

I also don't think that echo is a command for within sqlplus. Perhaps !echo might do the display or perhaps SELECT $name FROM dual ; would also do it.



Kind regards,
Robin
# 5  
Old 01-23-2018
You can read 5 lines at a time
Code:
while
  read name1 &&
  read name2 &&
  read name3 &&
  read name4 &&
  read name5
do
  echo "do something with $name1 $name2 $name3 $name4 $name5"
done < extract.txt

# 6  
Old 01-23-2018
Oracle does (seems to) have some PARALLEL execution Features ever since version 7.1. Do you want to deploy those or do you want to run five sqlplus *nix processes in background (as rbatte1 proposed)?
# 7  
Old 01-23-2018
Thanks for Quick response

Below code which we are doing manually (if extract.txt contains n record then loop count n/5 times parallel)

Code:
#!/bin/sh 

sqlplus -s connect << EOF
userid/password@database
@1.sql
@2.sql
@3.sql
@4.sql
@5.sql
exit
EOF

sqlplus -s connect << EOF
userid/password@database
@6.sql
@7.sql
@8.sql
@9.sql
@10.sql
exit
EOF

sqlplus -s connect << EOF
userid/password@database
@11.sql
@12.sql
@13.sql
@14.sql
@15.sql
exit
EOF


Last edited by umk; 01-23-2018 at 08:37 AM..
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

For loop or while loop from a text file

Hi all, i developed a script to measure the uptime of a process in a Solaris 10/11 environments. All is well, but i came across a situation where there are multiple processes of the same name. Basically i have the following result file: beVWARS 13357 19592122 beVWARS 14329 19591910... (4 Replies)
Discussion started by: nms
4 Replies

2. Shell Programming and Scripting

awk loop using array:wish to store array values from loop for use outside loop

Here's my code: awk -F '' 'NR==FNR { if (/time/ && $5>10) A=$2" "$3":"$4":"($5-01) else if (/time/ && $5<01) A=$2" "$3":"$4-01":"(59-$5) else if (/time/ && $5<=10) A=$2" "$3":"$4":0"($5-01) else if (/close/) { B=0 n1=n2; ... (2 Replies)
Discussion started by: klane
2 Replies

3. Shell Programming and Scripting

Reset while loop to loop same file multiple times

Hi, I want to read file multiple times. Right now i am using while loop but that is not working. ex. While read line do while read line2 do echo stmt1 #processing some data based on data., done < file2.txt done < file1.txt # This will have 10... (4 Replies)
Discussion started by: tmalik79
4 Replies

4. Shell Programming and Scripting

Array Variable being Assigned Values in Loop, But Gone when Loop Completes???

Hello All, Maybe I'm Missing something here but I have NOOO idea what the heck is going on with this....? I have a Variable that contains a PATTERN of what I'm considering "Illegal Characters". So what I'm doing is looping through a string containing some of these "Illegal Characters". Now... (5 Replies)
Discussion started by: mrm5102
5 Replies

5. Shell Programming and Scripting

My for loop decides to become an infinite loop?

Hi, I was debating if I should put this in the dummies or scripts section, I apologize in advance if I chose poorly. Fairly new to Unix and BASH scripting but I thought I made it fairly well given my limited understanding. However, the output indicates that it's looping and I'm ending up with a... (5 Replies)
Discussion started by: gotreef
5 Replies

6. Shell Programming and Scripting

S# in a for loop - concatenate $(loop counter)

Hi, hope I am posting in the right section. My problem is that I have 2 or more arguments passed and I want to check if the arguments passed exists or not. The first argument should not exist and the remaining others should exist. example: ./shells.sh argument1 argument2 argument3 ... (5 Replies)
Discussion started by: fight4love
5 Replies

7. Shell Programming and Scripting

BASH loop inside a loop question

Hi all Sorry for the basic question, but i am writing a shell script to get around a slightly flaky binary that ships with one of our servers. This particular utility randomly generates the correct information and could work first time or may work on the 12th or 100th attempt etc !.... (4 Replies)
Discussion started by: rethink
4 Replies

8. Shell Programming and Scripting

Null Handling in Until loop. . .loop won't stop

Hi Im running this script, which is supposed to find the max value build some tables and then stop running once all the tables are built. Thing is , it keeps assigning a null value to $h and then $g is null so it keep building tables i.e. testupdateNUL. How can I stop this? Here is what I have: ... (4 Replies)
Discussion started by: brandono66
4 Replies

9. Shell Programming and Scripting

Using variables created sequentially in a loop while still inside of the loop [bash]

I'm trying to understand if it's possible to create a set of variables that are numbered based on another variable (using eval) in a loop, and then call on it before the loop ends. As an example I've written a script called question (The fist command is to show what is the contents of the... (2 Replies)
Discussion started by: DeCoTwc
2 Replies

10. Shell Programming and Scripting

Is there a better way I could have run this loop. (For loop with two variables)

Sorry for such a dreadful title, but I'm not sure how to be more descriptive. I'm hoping some of the more gurutastic out there can take a look at a solution I came up with to a problem, and advice if there are better ways to have gone about it. To make a long story short around 20K pieces of... (2 Replies)
Discussion started by: DeCoTwc
2 Replies
Login or Register to Ask a Question