我搜索并找到了这篇文章 (http://stackoverflow.com/questions/1814297/cant-load-file-data-in-the-mysql-directory),但它对我不起作用。
我是 un Ubuntu 12.04,MySQL 版本是 5.5.22-0ubuntu1
我已经以 root 身份登录到 MySQL,所以授权应该没问题:
mysql> show grants;
+---------------------------------------------------------------------+
| Grants for root@localhost |
+---------------------------------------------------------------------+
| GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION |
| GRANT PROXY ON ''@'' TO 'root'@'localhost' WITH GRANT OPTION |
+---------------------------------------------------------------------+
我正在尝试将文本文件中的一些数据插入 MySQL 数据库,但 LOAD_FILE
函数似乎无法正常工作
我创建了一个测试文件,权限为 777 并复制到安装的根目录(我尝试将所有者/组更改为 root:root 和 mysql:mysql 但仍然没有用):
mysql> select load_file('/test.txt');
+------------------------+
| load_file('/test.txt') |
+------------------------+
| NULL |
+------------------------+
1 row in set (0.00 sec)
但如果我尝试这样做:
mysql> select load_file('/etc/hosts');
它工作正常。如果我将测试文件复制到 /etc
中,它仍然失败。
有没有人以前见过这个或者可以告诉我另一种加载到数据库中的方法?
最佳答案
使用load_file
,必须满足以下条件(来自 documentation ):
- 文件必须位于服务器主机上
- 您必须指定文件的完整路径名,并且必须有
FILE
特权。 - 文件必须对所有人都可读,并且其大小小于
max_allowed_packet
。字节。 - 如果
secure_file_priv
系统变量设置为非空目录名,要加载的文件必须位于该目录中。
如果文件包含您要执行的 SQL 语句,更简单的方法可能是将其通过管道输入:
mysql -u foo -p dbname < filename.sql
关于mysql - 替代 LOAD_FILE() 函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11012445/