mysql数据库导出导入问题,解决加50分!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql数据库导出导入问题,解决加50分!相关的知识,希望对你有一定的参考价值。

现在数据库中已经存在了一千多条记录需要更换编码,但是数据库默认编码是litan1
其中的中文在phpmyadmin和Navigate上面显示全为乱码
但是直接在mysql comand line client中的命令行里面是好的

请问各位大侠该怎么办?
下面是我试过的集中方法好像不怎么管用:
1.直接更改my.ini中的默认编码为gbk或者gb2312或者utf8
2.mysqldump -u root -p dbname > 1.sql 为乱码
3.mysqldump -default-character-set=latin1 -u root -p dbname > 1.sql命令导出却没有数据
4.导出到excel显示正常,但无法从excel导入显示的错误为[Imp] 1366 - Incorrect string value: '\xE5\xBE\x8B\xE6\x89\x80...' for column 'title' at row 1

可能经过乱七八糟的方法之后数据可能乱七八糟了!不过litan1编码下中文还是显示正常的!

1. my.ini 里面分为很多个节,有[mysqld] 的,也就是数据库的。也有[mysql]节的,是命令行工具的。
2. my.ini 为数据库全局默认设置,已经存在的表和数据库不会被改变。
3. 新建数据库和表的时候可以指定各自的默认编码,所以,建议创建一个和原来表结构相同的表,但指定编码,然后 select into 到新表之中,测试,如果可以,那么清空原来的表,然后从新表选择回来。
4. 如果导出为excel了,那么,excel另存为 txt制表符分割,然后使用工具插入。
参考技术A 以前我有个文学社,8年前的,老牌MYSQL都是那样的,后面升级后导出来的数据也是乱码,针对这个问题我是按照下面几点解决的!
针对上面乱码情况:
1.新建一个数据库ABC,属性为UTF8,这点切记!
2.用Navigate导出为文本格式的SQL文件,打开看是否乱码,若乱码,则采用PHP直接读取显示,字段之间用分隔符|然后把网页别存为TXT文件,再用EXECEL导入成为正常表.
3.用PHP读取SQL文件中命令行,并执行到新建的数据库ABC中,PHP编码要选对哦,全是UTF8的.
4.再导出来就肯这不是乱码.
参考技术B 你先导出来. .sql文件.
然后修改sql里的编码.再修改文件的编码.
再导入就行了.这个以前经常遇到
参考技术C Navigate 转储存为sql文件 导出的sql里面 在创建表的那个地方(DEFAULT CHARSET=utf8;) 把编码设置成utf8 然后再重新把sql文件运行一下。只要你导出来的sql文件里面中文没乱码 就什么都好说了。

将mongodb 数据指定字段导出,然后指定字段导入mysql 实例 及相关问题解决

需求:将mongodb 数据指定字段导出,然后再指定字段导入mysql  表中




直接上图吧,


最后 会将遇到几个问题及解决方案贴出,以便遇到类似问题可以迅速解决(期间所用命令具体用法不在本文详解之内)



  1. 将mongodb 数据指定字段导出,所用命令Mongoexport ,具体查阅官方文档;

技术分享


导出指定二级字段 Mongodb 

/opt/mongodb/bin/mongoexport  --host yourip  --port yourport   -d app_form -c application_data  --csv  --out export2.csv  --fields   applicant.name,applicant.id_card_num,applicant.cell_phone_num,applicant.home_addr


技术分享





2. 在mysql 机器上 rsync 传输过来,rysnc 用法就不讲了,带过

rsync -chavzP --stats [email protected]:/home/mongodata/export.csv   /data/mysql/





3.导入mysql,这里有两种情况,一种是导入全新的表,另一种则是导入已存在的表,但是需要指定该表具体字段


  1. 新表:

  2. LOAD DATA INFILE ‘/data/mysql/export2.csv‘  INTO TABLE temp_test  CHARACTER SET utf8  FIELDS TERMINATED BY ‘,‘ ENCLOSED BY ‘"‘;


  1. 老表指定字段:

  2. LOAD DATA INFILE ‘/data/mysql/export2.csv‘  INTO TABLE temp_test2  CHARACTER SET utf8mb4 FIELDS TERMINATED BY ‘,‘ ENCLOSED BY ‘"‘ (name,idcard,tellnumber, address);


结果验证:

技术分享

导入成功;






4.疑难杂症1:mongo 导出时二级字段的正确导出方法


技术分享





4.疑难杂症2:mysql导入时 ERROR 1366 (HY000): Incorrect string value: ‘\xF0\xA5\x8C\x93\xE5\x85...‘ for column ‘address‘ at row 45293 解决 方法

这个问题很难解决,一般是认为utf8mb4 所导致,具体原因看下面,需要修改表的默认字符集,并以指定utf8mb4 导入;


技术分享


技术分享


ALTER TABLE temp_test2  CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;  修改即可1





4.疑难杂症3:mongo 导入时ERROR 1262 (01000): Row 1066659 was truncated; it contained more data than there were input columns 解决方法,sql_mode 的问题,需要修改;

技术分享






5.其他问题,比如主键重复,字段大小不满足要求,等等小问题自行琢磨解决


最后正常的结果显示:

技术分享




百度内搜到的帖子能解决此类问题的很少,并且都不是完整的实例,这里贴出完整的整个操作实例,希望对大家有帮助;





本文出自 “linux-centos笔记” 博客,请务必保留此出处http://fuyuan2015.blog.51cto.com/8678344/1775054

以上是关于mysql数据库导出导入问题,解决加50分!的主要内容,如果未能解决你的问题,请参考以下文章

通过cmd窗口导入导出mysql数据库

mysql查询结果数据导出 into fileout 和cvs/txt等相关文件导入数据库中

mysql 数据库导入 导出,解决 导入 错误问题

secure_file_priv配置项对导入导出数据的影响

将mongodb 数据指定字段导出,然后指定字段导入mysql 实例 及相关问题解决

MySQL 表数据的导入导出