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

该命令:

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

再进入数据库就可以用了

参考:

http://greproot.com/the-used-command-is-not-allowed-with-this-mysql-version/
其他关于load的用法:http://www.cnblogs.com/ggjucheng/archive/2012/11/05/2755683.html


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,也暂时没发现对应的语句,有待继续学习.




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值