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

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

vardhan 2月前

56 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)
  • 如果您使用的是 Java 8+、Mysql 8.0+ 和 Connector/J 库 8.0.18,那么您可能会遇到诸如“此版本不支持命令”或类似的问题。

    要解决该问题,您必须添加属性,告知preparedStatement全部加载本地文件。您必须添加配置,我在连接url中配置它并解决了该问题。

    jdbc:mysql://localhost:3306/tempDB?allowLoadLocalInfile=true
    

    我还在 my.cnf 文件中做了一些更改,例如:

    1. local_infile = 1
  • 我说这不是任何 RDBMS 都支持的功能,因为它没有任何意义。您不能使用字符串作为标识符。大多数编译语言也是如此 - 您无法实例化对象,例如 new 'Classname'() 或 new stringvar(),其中 stringvar 命名您要创建的类。

  • @jww 那么,您能举一个强类型语言的例子吗?在这种语言中,您可以根据字符串变量中的函数或类的名称来调用函数或实例化类?我知道 Java 中的反射和 PHP 中的变量变量等,但关键是它需要额外的代码或额外的语法,而且通常采用两步方法 — 就像 SQL 中的准备一样。

  • 不,抱歉,我不能。我不是 SQL 专家。我大概每三五年使用一次 SQL。不过,我可以给你一些其他允许你在 Hello World 程序中使用变量的语言的例子。据我所知,SQL 是唯一一种不能使用变量的语言,你必须做一些准备变量的事情(有时,直到它像现在这样崩溃)。

  • @jww 您能举一个允许这样做的其它 RDBMS 的例子吗?USE 的参数是标识符,而不是字符串值。但会话变量和查询参数始终被视为值。据我所知,在任何品牌的 RDBMS 中,您都不能将会话变量或查询参数用作任何类型的 SQL 查询中的标识符。

  • Oracle 和 MySQL 太烂了。你甚至不能使用 @MY_DB_NAME;或者准备它。Oracle 应该为自己感到羞耻。

  • 你不能用它 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\' 扩展名,因此您可以使用任何文件扩展名,或者不使用任何扩展名。

返回
作者最近主题: