8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

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

vardhan 2月前

53 0

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

帖子版权声明 1、本帖标题:MySQL 加载数据:此命令尚不支持准备好的语句协议
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由vardhan在本站《mysql》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 我说这不是任何 RDBMS 都支持的功能,因为它没有任何意义。您不能使用字符串作为标识符。大多数编译语言也是如此 - 您无法实例化对象,例如 new 'Classname'() 或 new stringvar(),其中 stringvar 命名您要创建的类。

返回
作者最近主题: