连接在bash脚本中的for循环中只执行一次的mysql的方法?

时间:2015-01-21 07:45:28

标签: mysql bash

我有一个脚本会执行插入查询n次 - 因为我已经使用了FOR循环,但问题是连接到远程mysql的命令也会执行n次。这是更好地解决我的问题的脚本。

#!/bin/bash -X
#fields:  id|alias|booking_time|contact_no|deleted|grace|number_in_queue|pax|seated_time|status|walk_in_time|queue_id|user_id 

echo "Bash version ${BASH_VERSION}..."

for i in {1..5..1}
do
        _alias="Name$i"
        _contact_no=$(cat /dev/urandom | tr -dc '1-9' | fold -w 10 | head -n 1)
        _deleted="FALSE"
        _number_in_queue=$i
        _pax=$(( $RANDOM % 10 + 20 ))
        _status="waiting"
        _queue_id=424
        _user_id=550

        mysql -u root -p restbucks << EOF  #Want this to execute only One time
        INSERT INTO queue_item  VALUES ('','$_alias',now(),'$_contact_no','$_deleted',NULL,'$_number_in_queue','$_pax',now(),'$_status',now(),'$_queue_id','$_user_id');

EOF

done

每当我尝试运行脚本时,它都会向我询问密码。我想要的只是连接一次。

2 个答案:

答案 0 :(得分:1)

您可以在for循环之前移动mysql连接。

mysql -u root -p restbucks << EOF  #this execute only One time
for i in {1..5..1}
do
.....
done
EOF

此外,建议您可以将查询写入文件,然后使用单个连接最终执行该文件。

您可以参考bulk-mysql-query

答案 1 :(得分:0)

这是因为它被放置在for循环中。每次控件传递给循环时都会执行。连接后,您不需要连接到服务器。尝试将语句放在FOR语句之前。