mysql通过命令行导入导出问题

不同版本的mysql server间倒腾数据时经常会报错,比如,从5.6.21生成的脚本文件中,int,bigint,datetime等类型都指定了长度:int(10),bigint(19),datetime(6)等,在导入到另一个版本为5.1.42的server时就会提示导入失败。将这些长度限制删除就可以了,这些自动的具体长度在5.1.42中会默认生成(不同于5.6.21中的指定长度)。

另一个问题是权限问题,DEFINER=`dbcreator`@`localhost` SQL SECURITY DEFINER,这个语句中dbcreator是源服务器中创建数据库的用户,在目标服务器中可能没有同名用户,也会导致导入错误。有人建议在目标服务器中创建该用户,另一个做法是将dbcreator全局替换为root,然后在源服务器上用下列命令行保证root对数据对象的存取权限: grant all on *.* to root identified by 'root_password'.

另:数据脚本导出,以及通过脚本导入到数据库的命令分别如下:

导出:
mysqldump -u root -p database_name > file.sql
导入:
mysql -u root -p database_name < file.sql

其中file.sql需要替换为完整的文件路径。

 

转载于:https://www.cnblogs.com/awar/p/5110245.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值