load语句导入数据到mysql

阅读: 评论:0

load语句导入数据到mysql

load语句导入数据到mysql

该命令:

Load Data Local InFile &#' Into Table table_name;

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

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

过程中遇到过的问题:

1.默认安装时没有配置,会显示:

The used command is not allowed with this MySQL version

解决办法:

修改配置文件:

sudo nano(或vim) /etc/mysql/myf

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

--------myf中:

[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/sqld

把要导入的文件的路径加到最后,

eg./home/文件夹/* r,

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

保存退出

sudo /etc/init.d/apparmor reload

参考:

和 Load Data InFile 相反的命令是

Select * From table_name Into OutFile 'C:/';

把数据表的数据导出到txt

遇到的问题:

Can't create/write (Errcode:13)

原因:权限不够

方法:修改配置文件

sudo nano(vim) /etc/mysql/myf

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

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

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

本文发布于:2024-01-28 07:22:17,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/17063977435751.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:语句   数据   load   mysql
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23