酷站(www.ku0.com)-致力于为互联网从业者提供动力!

热门关键词:  企业  baidu  as  c4rp3nt3r  美女
酷站

Mysql

旗下栏目: Mysql MsSql DB2 Redis mariadb Access oracle MongoDB PostgreSQL SQLite mssql2005 mssql2008

mysql关联两张表时的编码问题及解决办法

来源:互联网搜集 作者:秩名 人气: 发布时间:2019-09-01
本篇文章主要介绍了mysql关联两张表时的编码问题及解决办法,对大家的学习或者工作具有一定的参考学习价值,感兴趣的小伙伴们可以参考一下,也感谢大家对酷站(ku0.com)的支持。

Mysql关联两张表时,产生错误提示Illegal mix of collations

1、先用工具把数据库、两张表的编码方式改变

2、这步很重要,需要改变字段的编码方式。
 

ALTER TABLE `表名` CHANGE `dev_chancode` `字段` VARCHAR(32) CHARACTER SET gbk NOT NULL;

总结:在建表时一定注意统一的编码方式,后续搞来搞去超级麻烦。

如何解决MySQL表编码转换问题?
 
  • 将待导出的数据表的表结构导出(可以用Phpmyadmin、mysqldump等,很简单就不说了),然后将导出的create table语句的CHARSET=latin1改为CHARSET=utf8,在目标库newdbname中执行该create table语句把表结构建好,接下来开始导出-导入数据。
  •  
  • 命令:./mysqldump -d DB_Dig > /usr/local/tmp/tables.sql
  •  
  • 命令行:进入mysql命令行下,mysql -hlocalhost -uroot -p*** dbname
  •  
  • 执行SQL select * from tbname into outfile '/usr/local/tbname.sql';
  •  
  • 将tbname.sql转码为utf-8格式,建议使用UltraEditor,可以直接使用该编辑器的'转换->ASCII到UTF-8(Unicode编辑)',或者将文件另存为UTF-8(无BOM)格式
  •  
  • 在mysql命令行下执行语句 set character_set_database=utf8; 注:设置mysql的环境变量,这样mysql在下一步读取sql文件时将以utf8的形式去解释该文件内容
  •  
  • 在mysql命令行下执行语句 load data infile 'tbname.sql' into table newdbname.tbname;
原文链接:https://www.cnblogs.com/Anders888/p/11441838.html

最新更新