mysql关联两张表时的编码问题及解决办法
2019-09-01 15:33
1146 查看
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;
以上就是本次介绍的全部知识点内容,感谢大家的学习和对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- 【PHP问题大全】--PHP连接MySQL出现乱码的编码解决办法
- MySQL中日期比较时遇到的编码问题解决办法
- MySQL中日期比较时遇到的编码问题解决办法
- mysql修改my.ini配置文件后无法启动问题解决办法,及修改mysql默认编码为utf8mb4的方法
- 关于linux下使用phpmyadmin给mysql表关联外键的问题和解决办法
- 关于linux下使用phpmyadmin给mysql表关联外键的问题和解决办法
- [MySQL-server-standard-5.0.19-0.rhel4.x86_64.rpm]安装的一个问题的解决办法
- DBDesigner 4 连接MySQL 5问题及解决办法
- 解决MySQL server has gone away问题的两种有效办法
- URL传递中文UTF-8编码问题解决办法
- MYSQL 8小时断开链接问题和解决办法
- IE8下utf-8编码页面乱码问题解决办法
- mysql中RAND()随便查询记录效率问题和解决办法分享
- Php+MYSQL中文编码问题解决全过程
- PHP MySQL字符集 乱码问题解决办法
- mysql默认编码设置成gbk,解决dos下查询中文乱码的问题!
- mysql 数据库查询随机数量条目的效率问题及解决办法【转】
- mysql存储过程中 乱码问题解决办法
- php和mysql中uft-8中文编码乱码的几种解决办法
- mysql解决编码问题