温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

普通数据文件导入mysql出现问题如何处理

发布时间:2020-04-23 11:46:47 来源:亿速云 阅读:350 作者:三月 栏目:MySQL数据库

下文内容主要给大家带来普通数据文件导入mysql出现问题如何处理,这里所讲到的知识,与书籍略有不同,都是亿速云专业技术人员在与用户接触过程中,总结出来的,具有一定的经验分享价值,希望给广大读者带来帮助。

 

一、问题描述

    数据文件 a.txt 导入mysql表中。

1、第一个问题

# mysqlimport -uabc -p'123' -h db1 -P 3306 DB a.txt
ERROR 1045 (28000): Access denied for user 'root'@'db1' (using password: YES), when using table:

    在排除密码和格式填写错误之后,查看mysql.user表 ,确认是否有File权限。

    确认之后确实没有File权限。更新mysql.user表的File权限为'Y',刷新权限。

> flush privileges;

普通数据文件导入mysql出现问题如何处理

2、第二个问题

重新执行导入命令

# mysqlimport -uabc -p'123' -h db1 -P 3306 DB a.txt
mysqlimport: Error: 1290, The MySQL server is running with the --secure-file-priv option so it cannot execute this statement, when using table:

    --使用load data infile 也报相同错误。

查看--secure-file-priv参数

> show global variables like 'secure_file_priv';
+------------------+-----------+
| Variable_name    | Value     |
+------------------+-----------+
| secure_file_priv | /dev/null |
+------------------+-----------+

    此参数不是动态参数。需要添加配置文件,重启服务才可以生效。

    1)不限制导入导出

# cat /etc/my.cnf
    [mysqld]
    secure_file_priv

    2)限制在特定目录下

# cat /etc/my.cnf
    [mysqld]
    secure_file_priv    = /tmp

        --只允许/tmp目录下的数据文件可以导入,其他目录下的文件没有权限导入。


    因为我们使用的是腾讯云的mysql数据库,这个参数不能修改,但是我们又必须有导入导出的功能,所以我们只能自建实例,自己做限制。


3、第三个问题

# mysqlimport -r --host="db1" --port="3306" --user="abc" --password="123"  --fields-terminated-by="\t" --lines-terminated-by="\n" --columns="a,b,c,d" DB "/tmp/a.txt"
mysqlimport: Error: 13, Can't get stat of '/data/codebase/a.txt' (Errcode: 2 "No such file or directory"), when using table: a

    默认是找mysql库所在云服务器的/tmp目录下的文件,而不是执行命令的机器。

    加 --local 参数,表示指定的导入文件是执行命令的机器。

对于以上关于普通数据文件导入mysql出现问题如何处理,如果大家还有更多需要了解的可以持续关注我们亿速云的行业推新,如需获取专业解答,可在官网联系售前售后的,希望该文章可给大家带来一定的知识更新。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI