我正在尝试编写一个 MySQL 脚本,将数据导入到我的 Linux 服务器的表中。以下是名为 update.sql 的脚本:SET @query = CONCAT(\'LOAD DATA LOCAL INFILE '\', @spaceName, \'' INTO TABLE tmp
我正在尝试编写一个 MySQL 脚本,将数据导入到我的 Linux 服务器的表中。以下是名为 的脚本 update.sql
:
SET @query = CONCAT("LOAD DATA LOCAL INFILE '", @spaceName, "' INTO TABLE tmp FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n';");
PREPARE stmt FROM @query;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
另外,我还编写了一个名为 main.sh
:
mysql -h "localhost" -u "root" "-pmypassword" "mydb" -e "set @spaceName=\"$1\";source update.sql;"
然后我执行 ./main.sh France.list
。这 France.list
是我尝试导入数据库的数据文件。
但是我收到一个错误:
文件“update.sql”第 2 行出现错误 1295 (HY000):此命令在准备好的语句协议中尚不受支持
我发现了这个问题:
MySQL - 使用变量路径加载数据文件
那么,这是否意味着没有办法将参数传递给 LOAD DATA
查询?
你不能用它 PREPARE
来跑 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"
另一种更简单的方法是使用 mysqlimport ,但这要求输入文件名与表名相同。您可以重命名输入文件以匹配要加载到的表(您称之为 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\' 扩展名,因此您可以使用任何文件扩展名,或者不使用任何扩展名。