MySQL加载数据:准备好的语句协议尚不支持该命令

2023-12-01

我正在尝试编写一个 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;

而且,我编写了一个名为的 bash 脚本main.sh:

mysql -h "localhost" -u "root" "-pmypassword" "mydb" -e "set @spaceName=\"$1\";source update.sql;"

然后我执行./main.sh France.list. The France.list是我尝试导入到数据库中的数据文件。

但是我收到错误:

文件“update.sql”第 2 行出现错误 1295 (HY000):此命令是 准备好的声明协议尚不支持

我发现了这个问题:
MySQL - 使用可变路径加载数据文件

那么,这是否意味着无法将参数传递给LOAD DATA query?


你不能使用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”扩展名,因此您可以使用任何文件扩展名,也可以不使用。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MySQL加载数据:准备好的语句协议尚不支持该命令 的相关文章

随机推荐