阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

用LOAD命令批量导入文件内容到MySQL数据库中

129次阅读
没有评论

共计 1260 个字符,预计需要花费 4 分钟才能阅读完成。

该命令:

Load Data Local InFile ‘dir.txt’ Into Table table_name;

(规范貌似是除了文件名和表名是小写, 其他全部是大写, 我自己打的时候懒得分大小写, 它也默认能识别, 不过好像不太好)

忽略大小写, 默认同行数据间为 ’\t’, 一行以 ’\n’ 结束, 把文件里的数据安行 ` 读入到数据库中

过程中遇到过的问题:

1. 默认安装时没有配置, 会显示:
The used command is not allowed with this MySQL version

解决办法:
修改配置文件:

sudo nano(或 vim) /etc/mysql/my.cnf

找到 [mysqld] 和[mysql], 在下面加上 ”local-infile=1″

——–my.cnf 中:
[mysqld]
 local-infile=1

 [mysql]
 local-infile=1

 Save and quit the file.(nano 为 ctrl+x)
 ———————–

 sudo /etc/init.d/mysql restart

再进入数据库就可以用了

2. 经过以上修改可能只能成功一次, 之后再使用时又会有问题:

ERROR 29 (HY000): File ‘  ‘ not found (Errcode: 13)

原因:mysql 强制编码, 文件没有写入权限
 解决方法:
sudo nano(vim) /etc/apparmor.d/usr.sbin.mysqld
把要导入的文件的路径加到最后,

eg./home/ 文件夹 /* r,           
      /home/ 文件夹 /* rw,(两个都要)

保存退出

sudo /etc/init.d/apparmor reload

参考:http://blog.csdn.net/ljasdf123/article/details/17465767

 

和 Load Data InFile 相反的命令是
Select * From table_name Into OutFile ‘C:/Data_OutFile.txt’;

把数据表的数据导出到 txt

遇到的问题:

Can’t create/write to file….. (Errcode:13)

原因: 权限不够

方法: 修改配置文件
sudo nano(vim) /etc/mysql/my.cnf
找到 tmpdir 这一栏, 修改为 /var/lib/mysql/tmp(这是要导出文件的地方, 貌似必须与 datadir 相对应, 我移植了数据库, 所以路径会跟默认不一样, 关于移植数据库看上一篇笔记. 导出的地方没有查看权限, 在命令行下:sudo su 切换成 root 用户, 再进入相应位置查看

以上都是通过改数据库配置解决的问题, 还有其他一些问题也可以通过改数据库配置解决.

以上都是在 Ubuntu 命令行下才能成功, 在 Python 下用 cursor 操作数据库和用 Django 操作暂时没法使用 LOAD, 也暂时没发现对应的语句, 有待继续学习.

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-11/148347.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计1260字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中