错误 1148:此 MySQL 版本不允许使用的命令

2021-11-20 00:00:00 sql import mysql

我正在尝试使用

LOAD DATA LOCAL
INFILE A.txt
INTO DB
LINES TERMINATED BY '|';

这个问题的主题是我得到的回应.我知道默认情况下本地数据卸载是关闭的,我必须使用命令 local-infile=1 启用它,但我不知道在哪里放置这个命令.

the topic of this question is the response I get. I understand the local data offloading is off by default and I have to enable it using a the command local-infile=1 but I do not know where to place this command.

推荐答案

您可以在设置客户端连接时将其指定为附加选项:

You can specify that as an additional option when setting up your client connection:

mysql -u myuser -p --local-infile somedatabase

这是因为该功能打开了一个安全漏洞.所以你必须以明确的方式启用它,以防你真的想使用它.

This is because that feature opens a security hole. So you have to enable it in an explicit manner in case you really want to use it.

客户端和服务器都应该启用本地文件选项.否则它不起作用.要为服务器端服务器上的文件启用它,请将以下内容添加到 my.cnf 配置文件:

Both client and server should enable the local-file option. Otherwise it doesn't work.To enable it for files on the server side server add following to the my.cnf configuration file:

loose-local-infile = 1

相关文章