以下 shell 脚本未将数据插入表中。如何将变量值传递给 shell 脚本中的插入 sql 语句。
id=0
while true
do
id=`expr $id + 1`;
mysql -u root -ptest --socket=/data/mysql1/mysql.sock -e 'insert into mytest1.mytable2(id,name) values (' $id ',"testing");'
echo $id >> id.txt
done
我已按如下方式修改脚本并尝试,但问题仍然存在
id=0
while true
do
id=`expr $id + 1`;
# mysql -u root -ptest --socket=/data/mysql1/mysql.sock1 -e 'insert into mytest1.mytable1(name) values ("amma");'
mysql -u root -ptest --socket=/data/mysql1/mysql.sock -e 'insert into mytest1.mytable2(id,name) values ( $id ,"testing");'
echo $id >> id.txt
done
错误 :
]$ ./insert
ERROR 1054 (42S22) at line 1: Unknown column '$id' in 'field list'
答案1
这个应该可以工作:
id=0
while true
do
id=`expr $id + 1`;
mysql -u root -ptest --socket=/data/mysql1/mysql.sock -e "insert into mytest1.mytable2(id,name) values ($id, \"testing\");"
echo $id >> id.txt
done
双引号内的变量会被插入,而单引号之间的变量则不会被插入。