我有一个脚本会执行插入查询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
每当我尝试运行脚本时,它都会向我询问密码。我想要的只是连接一次。
答案 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语句之前。