加入收藏 | 设为首页 | 会员中心 | 我要投稿 温州站长网 (https://www.52wenzhou.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql关联两张表时的编码问题及处理办法

发布时间:2022-02-25 14:23:54 所属栏目:MySql教程 来源:互联网
导读:Mysql关联两张表时,产生错误提示Illegal mix of collations 1、先用工具把数据库、两张表的编码方式改变 2、这步很重要,需要改变字段的编码方式。 ALTER TABLE `表名` CHANGE `dev_chancode` `字段` VARCHAR(32) CHARACTER SET gbk NOT NULL; 总结:在建表
       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;

(编辑:温州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读