mysql关联两张表时的编码问题及解决办法
程序员文章站
2022-04-10 22:41:50
mysql关联两张表时,产生错误提示illegal mix of collations
1、先用工具把数据库、两张表的编码方式改变
2、这步很重要,需要改变字段的编码方...
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;
以上就是本次介绍的全部知识点内容,感谢大家的学习和对的支持。
上一篇: 往MySQL中存储图片的方法