Something wrong with while loop


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Something wrong with while loop
# 1  
Old 07-02-2010
Question Something wrong with while loop

Hi there, i've written a script to extract a portion of a MySQL database table and convert it to CSV and then to import it back as CSV to MySQL. Initially it worked without the while loop but after adding the while loop statement, i am getting the following error:
Code:
./export-csv-coordinates.sh: line 49: warning: here-document at line 18 delimited by end-of-file (wanted `EOFMYSQL')
./export-csv-coordinates.sh: line 50: syntax error: unexpected end of file

Here's my script:

Code:
#!/bin/bash
while :
do
    clear
    echo "Server Name - $(hostname)"
    echo "-------------------------------------"
    echo "                MAIN MENU              "
    echo "-------------------------------------"
    echo "1. Export coordinates as csv file"
    echo "2. Import csv file to update database"
    echo "3. Exit"
    read -p "Enter your choice [ 1 - 3 ]" choice

    case $choice in
    1)
    echo "Exporting coordinates as CSV...please wait!"
    sleep 5
    mysql -uroot -proot iaf<<EOFMYSQL
    SELECT * INTO OUTFILE '/var/lib/mysql/nodecoordinates.csv' FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n' FROM sngnms_node_map_coordinate;
    EOFMYSQL
    echo "CSV created in /var/lib/mysql"
    read -p "Press [ENTER] key to continue..."
    readEnterKey;;
    2)
    file="/var/lib/mysql/nodecoordinates.csv"
    for f in $file
    do
        [ -f $f ] && echo "$f file found" || echo "*** Error -$f file not found!"
    done
    echo ""
    echo "Importing    CSV file to update database...please wait!"
    sleep 5
    mysql -uroot -proot iaf<<EOFMYSQL
    LOAD DATA INFILE '/var/lib/mysql/nodecoordinates.csv' INTO TABLE sngnms_node_map_coordinate FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n';
    EOFMYSQL
    /etc/init.d/mysql restart
    sleep 5
    echo "CSV file updated to current database"
    read -p "Press [ENTER] key to continue..."
    readEnterKey;;
    3)
    echo "Bye!"
    exit 0;;
    *)
    echo "Error: Invalid option..."
    read -p "Press [ENTER] key to continue..."
    readEnterKey;;
    esac
done

Could someone help in pointing what's wrong with my script. I am just beginning to learn scripting.

Thanks!
# 2  
Old 07-02-2010
Hi, place the end tag is at the beginning of the line.
# 3  
Old 07-02-2010
Quote:
Originally Posted by Klashxx
Hi, place the end tag is at the beginning of the line.
I'm sorry, but which end tag are u referring to? Smilie
# 4  
Old 07-02-2010
Quote:
Originally Posted by edge80
I'm sorry, but which end tag are u referring to? Smilie
These:
Code:
#!/bin/bash
while :
do
    clear
    echo "Server Name - $(hostname)"
    echo "-------------------------------------"
    echo "                MAIN MENU              "
    echo "-------------------------------------"
    echo "1. Export coordinates as csv file"
    echo "2. Import csv file to update database"
    echo "3. Exit"
    read -p "Enter your choice [ 1 - 3 ]" choice

    case $choice in
    1)
    echo "Exporting coordinates as CSV...please wait!"
    sleep 5
    mysql -uroot -proot iaf<<EOFMYSQL
    SELECT * INTO OUTFILE '/var/lib/mysql/nodecoordinates.csv' FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n' FROM sngnms_node_map_coordinate;
EOFMYSQL
    echo "CSV created in /var/lib/mysql"
    read -p "Press [ENTER] key to continue..."
    readEnterKey;;
    2)
    file="/var/lib/mysql/nodecoordinates.csv"
    for f in $file
    do
        [ -f $f ] && echo "$f file found" || echo "*** Error -$f file not found!"
    done
    echo ""
    echo "Importing    CSV file to update database...please wait!"
    sleep 5
    mysql -uroot -proot iaf<<EOFMYSQL
    LOAD DATA INFILE '/var/lib/mysql/nodecoordinates.csv' INTO TABLE sngnms_node_map_coordinate FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n';
EOFMYSQL
    /etc/init.d/mysql restart
    sleep 5
    echo "CSV file updated to current database"
    read -p "Press [ENTER] key to continue..."
    readEnterKey;;
    3)
    echo "Bye!"
    exit 0;;
    *)
    echo "Error: Invalid option..."
    read -p "Press [ENTER] key to continue..."
    readEnterKey;;
    esac
done

This User Gave Thanks to Klashxx For This Post:
# 5  
Old 07-02-2010
Gee, thanks! Did not realize that...
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

What's wrong with this while loop?

function get_tablespace() { ## Get the current size of the tablespace size=`su -l oracle -c 'db-control report' |egrep "DATA_TBS" | awk '{print $5}'|tr -d '%'` ## Loop through until the size is 82 or less count=0 while && do ... (2 Replies)
Discussion started by: bille
2 Replies

2. Shell Programming and Scripting

What is wrong with my if loop?

Hello everyone, I need a little help. I wrote a cshell script to change the format of a file but it is not working. input file is like that: 2014 3 20 15 0 5.270 40.7739 27.6471 20.232 0.6 0 0 0 1 Site6 4.081 1.00 P Site6 7.585 1.00 S Site1 4.441 1.00 P... (9 Replies)
Discussion started by: miriammiriam
9 Replies

3. 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

4. Shell Programming and Scripting

Why result is wrong here ? whether break statement is wrong ?

Hi ! all I am just trying to check range in my datafile pls tell me why its resulting wrong admin@IEEE:~/Desktop$ cat test.txt 0 28.4 5 28.4 10 28.4 15 28.5 20 28.5 25 28.6 30 28.6 35 28.7 40 28.7 45 28.7 50 28.8 55 28.8 60 28.8 65 28.1... (2 Replies)
Discussion started by: Akshay Hegde
2 Replies

5. UNIX for Dummies Questions & Answers

Loop and variable not exactly variable: what's wrong

Hello guys, This truly is a newbie question. I'm trying to make a loop to execute simultaneous commands indefinitely while using variable. Here is how my mess looks like (this is just an example): #!/bin/bash IP=`shuf -n 1 IP.txt` # I figured this would be easier to select random lines... (4 Replies)
Discussion started by: bobylapointe
4 Replies

6. Shell Programming and Scripting

what's wrong with that loop ?

hello everybody, here's my code mkf () { INDEX=0; while ; do touch "file$1.f"; INDEX=$INDEX+1; done } when I type mkf 10 the loop seems to act infinite and only the last file of the loop is created, in the example below, there just is file10.f in... (11 Replies)
Discussion started by: Oddant
11 Replies

7. Shell Programming and Scripting

Whats wrong with my Loop

Hi all, I have been given a task to search for strings in a file that is encoded. I need to display the file name only when all the 3 strings which i provide are present in the file name. i first try to get a list of files according from the directory according to the value passed in argument... (0 Replies)
Discussion started by: amit1_x
0 Replies

8. Shell Programming and Scripting

What is wrong in my IF loop ??

What is wrong in my IF loop if then echo " The request is authenticated " fi The error im getting is $ ./routing.sh server enables ********************************************************************** Preparing to service the request for Device server in Question... (9 Replies)
Discussion started by: raghunsi
9 Replies

9. Shell Programming and Scripting

Something went wrong in the following loop

The script is And the error is + count=2 ./FindEID.ksh: line 227: syntax error near unexpected token `else' ./FindEID.ksh: line 227: ` else' I just can't find out what the problem is, can anyone tell me about this error is? Thank you (5 Replies)
Discussion started by: tpltp
5 Replies

10. Shell Programming and Scripting

new to shell scripting: whats wrong with my if loop

#!/bin/bash for file in $HOME/*; do if ; then rm -i $file > /dev/null echo "$?" echo "$file has been deleted" fi done Been trying to learn shell scripting for a week or so now, when i run the script it doesnt display an error message, seems like it runs fine, however it doesnt delete... (10 Replies)
Discussion started by: stride6
10 Replies
Login or Register to Ask a Question