主页 > 知识库 > mysql关联两张表时的编码问题及解决办法

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

热门标签:怎么在地图标注位置生成图片 电销卡外呼系统供应商 铜陵防封电销卡 福建外呼系统定制化 真人语音电话机器人 悟空科技电话机器人 美国反骚扰电话机器人 腾讯地图标注提升 400电话可以免费申请吗

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

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

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

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

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

如何解决MySQL表编码转换问题

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

以上就是本次介绍的全部知识点内容,感谢大家的学习和对脚本之家的支持。

您可能感兴趣的文章:
  • MySQL中日期比较时遇到的编码问题解决办法
  • Mysql数据库编码问题 (修改数据库,表,字段编码为utf8)
  • Mysql5 字符集编码问题解决

标签:白银 湖南 云浮 乌海 湖北 武威 临汾 聊城

巨人网络通讯声明:本文标题《mysql关联两张表时的编码问题及解决办法》,本文关键词  mysql,关联,两张,表时,的,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《mysql关联两张表时的编码问题及解决办法》相关的同类信息!
  • 本页收集关于mysql关联两张表时的编码问题及解决办法的相关信息资讯供网民参考!
  • 推荐文章