loop problem


 
Thread Tools Search this Thread
Top Forums UNIX for Advanced & Expert Users loop problem
# 1  
Old 05-17-2009
loop problem

Hi guys my while do loop is not working properly;
As soon as the load_date and run_date is same it should stop can somebody tell me where I am having the problem?
In an oracle table I have
LOAD_DT=5/1/2009 DATE datatype
RUN_DT=5/5/2009 DATE datatype
Now in a script with a spool file I get the dates in char type
v_LOAD_DT==`head -n1 $spool | awk '{print $1}'`(20090501)
v_RUN_DT==`head -n1 $spool | awk '{print $1}'`(20090505)
while [$v_LAST_LOAD_DT -lt $v_RUN_DT]
do
#{Here I am incrementing the date]
sqlplus /nolog @increment.SQL $calc_spool
if [$? -ne 0]; then exit 1; fi
v_next_dt=`head -n1 $calc_spool | awk '{print $1}'`
echo "$v_NEXT_DT"
[$v_NEXT_DT -eq $v_RUN_DT]
#[Here I am updating the table with the next day ]
sqlplus /nolog @Update_dt.SQL $v_update
if [$? -ne 0]; then exit 1; fi
done
The problem with the syntax is the loop is not stopping. when the load_dt=run_dt the loop should stop.
But when I force it to stop I see the load_dt to be a much later date.I dont think the while do syntax is right.
And it seems it is not recognising [$v_NEXT_DT -eq $v_RUN_DT] syntax.
Can you tell me what is the problem?
Thanks in advance
# 2  
Old 05-18-2009
integers in condition needed

I think you should make sure that your variables are proper integers.
You can use "typeset -i name=value" or "integer name=value".
Unless you use integers, your condition would not work.
# 3  
Old 05-18-2009
There must be a space after the opening bracket and a space before the closing bracket in your test statements, for example:

Code:
while [ $v_LAST_LOAD_DT -lt $v_RUN_DT ]

instead of:

Code:
while [$v_LAST_LOAD_DT -lt $v_RUN_DT]

Regards
# 4  
Old 05-18-2009
yes as franklin mentioned you need a space after "[" in every loop such as if while etc
# 5  
Old 05-18-2009
I got those spaces but still i am facing the same problem. IS my while do loop logic ok.
# 6  
Old 05-18-2009
Quote:
v_LOAD_DT==`head -n1 $spool | awk '{print $1}'`(20090501)
v_RUN_DT==`head -n1 $spool | awk '{print $1}'`(20090505)
why are you referencing the SAME field ($1) for both variables?

Also.......
Code:
v_LOAD_DT=$(awk 'FNR==1 {print $1;exit}' "${spool}")

# 7  
Old 05-18-2009
Thanks vgersh,

But that is not what I am looking at and I apologise that I confused you.

I should explain because I am really stuck.

In an oracle table I have
LOAD_DT=5/1/2009 DATE datatype
RUN_DT=5/5/2009 DATE datatype

with the help of spool file I am picking these variables up like 02-MAY-2009 and 05-MAY-2009

Now my question is with a do while loop I need to get the dates 03-MAY-2009, 04-MAY-2009 and 05-MAY-2009.

I am confused at where to initialize and totally confused with the loop.


I did this

while [ $LOAD_DT -lt $RUN_DT ]
do

#Here I will write a sqlplus code to increment the date
#I will get my other work done here

stop condition

done

#Here I will update my table with the next day sqlplus code


Just please suggest me the do while loop syntax for this case and the stop condition.
I am sure I am messing up at the initialising or stop condition.

Thanks to all of you,
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Problem with loop

Hi all, a problem with a loop. Imagine it starts with var1="$(cat txtif.out )"while do echo file1 echo file2 echo y > txtif.out if then break fi done exit 0 the problem is that if the file is changing during the loop seems to continue as it reads "x" state,... (5 Replies)
Discussion started by: Board27
5 Replies

2. Shell Programming and Scripting

Problem with While Do loop

I am trying to do a while do loop that asks for a password and returns if the password entered is incorrect. I have that part working however i want to modify it so that if a similar word is entered it will read "that is close but incorrect" and i cannot seem to get it working, being new in the... (6 Replies)
Discussion started by: lm5522
6 Replies

3. Shell Programming and Scripting

Problem with loop within loop

Hi, I work on Ab-initio ETL tool which is based on Unix. I made a small script which has two loop's one with in another. All the functionality is working for the first line of outer loop but when it comes to other lines of outer loop it is throwing error as command not found. Below is the... (4 Replies)
Discussion started by: Ravindra Swan
4 Replies

4. Shell Programming and Scripting

Problem with While loop.

Hi Script Gurus, I am facing issue with while loop in bash. The while loop is running as end less loop even after given criteria does not meet. STATE_BEFORE_SPLIT () { for clone in $Clonegroups; do state=$( $Navicmd -listclone -name $clone -cloneid $Cloneid |awk... (3 Replies)
Discussion started by: RobP
3 Replies

5. UNIX for Dummies Questions & Answers

While loop problem

I have a while loop with -f and -o option.Can any one please tell me what that stands for?The Sample code is as follows:- while do ## some processing done (10 Replies)
Discussion started by: Param0073
10 Replies

6. Shell Programming and Scripting

problem with while loop

hi I had created a while loop in a script file called whiletest.sh as follows as follows: count=0 max=10 while do echo $count echo count=$(count+1)" " done echo "value of count:$count" then i run the script with the command sh whilestest.sh but its giving me an error... (5 Replies)
Discussion started by: angel12345
5 Replies

7. Shell Programming and Scripting

problem with a loop

Hi What is wrong with this loop it was taken has a example in book!!! it returns then /usr/sbin/svcadm disable ppserv else /usr/sbin/ppadmin stop fi } (3 Replies)
Discussion started by: Ex-Capsa
3 Replies

8. Shell Programming and Scripting

Problem in While loop

Hi Guys, This is my code.. I am getting an error in the inside while statement when comparing.. I am not able to figure it out.. Pls help me... while read value fatherid son_id top_id r_type do inside_value=1; echo $inside_value; echo $r_type; while do echo... (6 Replies)
Discussion started by: mac4rfree
6 Replies

9. Shell Programming and Scripting

for loop problem

Hi, I have a directory called logs in which i have the log files. i have to touch the file before deleting it. i am doing like this filestodelete="*.log* *log*" for files in $filestodelete do touch $files $files.$(date +%a) rm -f $filestodelete done touch is not working... (5 Replies)
Discussion started by: namishtiwari
5 Replies

10. Programming

problem with while loop

hi all, i have written the following code: while(proceed !='Y' && proceed!='N' && proceed!='y' && proceed!='n') { printf("\nPress \n\t 'Y' or 'y' to continue \n\t 'N' or 'n' to cancel:"); scanf("%c",&proceed); } the output i am gettin is: Press 'Y' to continue ... (1 Reply)
Discussion started by: mridula
1 Replies
Login or Register to Ask a Question