微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我正在尝试编写一个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的bash脚本:

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

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

但是我得到一个错误

ERROR 1295 (HY000) at line 2 in file: ‘update.sql’: This command is
not supported in the prepared statement protocol yet

我发现了这个问题:
MySQL – Load Data Infile with variable path

那么,这是否意味着没有办法将参数传递给LOAD DATA查询

解决方法:

您不能使用PREPARE运行LOAD DATA INFILE.

您可以在PREPARE上运行的语句列表记录在以下页面中:https://dev.mysql.com/doc/refman/5.7/en/sql-syntax-prepared-statements.html,位于子标题“ Prepared Statements中允许的sql语法”下.注意,该列表在早期版本的MysqL中可能有所不同.

因为您不能使用PREPARE,所以无法通过设置变量并创建动态sql语句来执行所使用的方法.

但是您可以在不使用PREPARE的情况下运行LOAD DATA INFILE.您必须使用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”扩展名,因此您可以使用任何文件扩展名,也可以不使用.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐