你不能使用PREPARE
to run LOAD DATA INFILE
.
您可以运行的语句列表PREPARE
记录在此页面中:https://dev.mysql.com/doc/refman/5.7/en/sql-syntax-prepared-statements.html在“准备好的语句中允许的 SQL 语法”小标题下。请注意,此列表在早期版本的 MySQL 中可能有所不同。
因为你不能使用PREPARE
,您无法通过设置变量并创建动态 SQL 语句来执行您正在使用的方法。
但你可以跑LOAD DATA INFILE
不使用PREPARE
。您必须使用 shell 变量替换将文件名插入到语句中,然后将其作为直接 SQL 语句运行。
您的 update.sql 文件可能如下所示:
LOAD DATA LOCAL INFILE '%spacename%' INTO TABLE tmp
FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n';
然后您可以将 shell 变量替换到该文件中并以这种方式运行结果:
sed s/%spacename%/$1/ update.sql |
mysql -h "localhost" -u "root" "-pmypassword" "mydb"
另一种更简单的方法是使用mysql导入,但这要求输入文件名与表名相同。您可以重命名输入文件以匹配要加载到的表(您称之为tmp
),或者创建一个符号链接:
ln -s $1 /tmp/tmp.list
mysqlimport --local -h "localhost" -u "root" "-pmypassword" "mydb" /tmp/tmp.list
rm -f /tmp/tmp.list
mysqlimport 会忽略“.list”扩展名,因此您可以使用任何文件扩展名,也可以不使用。