php mysql 编码问题
php mysql 编码问题
问题:
PHP从数据库中读取数据,并echo出来,数据中文显示正常;但是echo出新定义的中文字符串,新定义的字符串会乱码。
由此可能是数据库中提取出来的中文编码和php的输出编码不一样。
操作:
在head中添加<meta charset="UTF-8">,定义页面编码。
问题:
PHP本身输出的中文编码正确了,但是从数据库中提取出来的中文编码错了。
由此可见,数据库提取出来的中文编码是可辨认的,在数据库中直接查询,也不会乱码。之后的乱码是因为数据库提取出来的中文编码与PHP本身输出的编码不同,选前者后者就乱码,选后者前者就乱码。
解决方法1:
$encode = mb_detect_encoding($sqldata, array("ASCII",'UTF-8',"GB2312","GBK"));
if ($encode == 'EUC-CN') {
$newsqldata = iconv('GBK', 'UTF-8', $sqldata);
echo $newsqldata;
echo "</br>";
}
查询数据库中提取中文的编码,是EUC-CN,gb2312的一种表示方式。使用iconv将GBK转换为UTF-8,则数据库提取的中文编码也是utf-8,与PHP本身输出相同,就不会乱码了
解决方法2:
数据库中的数据存入时是用python存入的,规定了连接方式为utf-8;在python中,所有数据也一致处理为utf-8再存入。
本身以为这样子就OK了,但是出了这个问题后,查看MySQL编码时,发现其gkb
所以单纯设定python连接编码、统一数据编码还不够,还需要修改数据库的编码。
所以要根源上处理该问题,就修改数据库的编码为utf-8。
解决方法3:
在mysql_query前执行以下命令
mysql_query("SET NAMES 'UTF8'");
博大精深的问题:https://blog.csdn.net/wzwsj1986/article/details/1723658
为了保险,还是加上吧,不管改了数据库的编码没有。
[ 另外 ]
MySQL ini设置编码为utf8,传入的也为utf8,但是在数据库中查询时,中文却是乱码的。
在数据库乱码的情况下,用数据库命令行 存入数据库数据,查询出来的时候就是乱码的。
但是命令行模式的数据库乱码,不影响存取,没关系,最可能的情况是
1. 当前DOS窗口的编码有问题。
2. 当前数据库session的编码有问题。
THAT'S ALL .
php mysql 编码问题的更多相关文章
- mysql编码的那点事
Mysql编码问题 在php页面可以向mysql插入英文字符,但就是不能插入中文字符,在cmd客户端也可从插入,这是困扰我两天的问题. 在网上找了很多资料,最终确定了是字符编码这个地方出现了问题,首 ...
- Linux(Ubuntu)使用日记------Mysql编码(utf-8)的设置
Mysq版本:5.7.21 操作系统:Linux(Ubuntu) 整个操作的基本思路如下(包括问题的解决思路,想要直接解决问题的可以先看最后的命令总结) 检查mysql编码 找到Mysql的配置文件 ...
- linux上设置mysql编码
linux下设置mysql编码 linux下设置mysql编码 首先查找MySql的cnf文件的位置: [root@flyHome gaoxiang]# find / -iname '*.cnf' - ...
- MYSQL进阶学习笔记一:MySQL编码设定,会话变量和全局变量!(视频序号:进阶_1-3)
知识点一:MySQL编码设定(1-2) 服务器编码设定: 查看MySQL服务器端的编码格式: SHOW VARIABLES LIKE ‘char%’; 设定编码格式: SET NAMES ‘utf8’ ...
- 关于mysql编码问题
1 查看MySQL编码 SHOW VARIABLES LIKE 'char%';
- 配置mysql 编码
配置mysql 编码 [client]default-character-set=utf8mb4 default-storage-engine=INNODB [mysql]default-charac ...
- mac mysql 编码配置
mac mysql 编码配置 (mysql目录下没有my.cnf) 想要修改编码发现自己的/usr/local/mysql/support-files里面根本没有my.cnf 安装方式是去mysql官 ...
- 【他山之石】mysql编码问题总结
有些问题可能比较基础,但是没有经过系统学习还是可能会出错,记录下. 这次是mysql的编码问题. 背景是部署新的测试环境,给了一台服务器还有在另一个环境下的mysql,配置过程中发现mysql编码有问 ...
- mysql编码设置
一:mysql字符集 mysql的字符集支持(Character Set Support)有两个类型:字符集(Character set)和连接校对(Collation).对于字符集的支持细化到四个层 ...
随机推荐
- Confluence 6 针对你的数据库类型确定校验 SQL
不同的数据库通常要求不同的 SQL 校验查询.校验查询通常需要尽可能的简单,这个查询在链接从数据库连接池中取出的时候都会被执行一次. 针对不同的数据库类型,我们推荐先的校验查询 SQL: MySQL ...
- libopencv_highgui.so.2.4.9:对‘TIFFReadRGBAStrip@LIBTIFF_4.0’未定义的引用
make之前加上sudo su重新make即可 http://blog.csdn.net/cfyzcc/article/details/52981467
- CentOS 7 防火墙,端口开启命令
1. 查看已打开的端口 # netstat -anp 2. 查看想开的端口是否已开 # firewall-cmd --query-port=8003/tcp 若此提示 FirewallD is ...
- mybatis 遍历map;
mybatis 遍历map; 参考http://blog.csdn.net/hj7jay/article/details/78652050 ps: ${m[key]}这是显示 打印的key读value ...
- 使用layer弹出Ueditor实现父子传值
Layear的代码: function tankuang() { layer.open({ type: 2, title: false ...
- KnockoutJs学习笔记(五)
作为一名初学者来说,一篇篇的按顺序看官网上的文档的确是一件很痛苦的事情,毕竟它的排列也并非是由浅及深的排列,其中的顺序也颇耐人寻味,于是这篇文章我又跳过了Reference部分,进而进入到具体的bin ...
- SQL Server中Text和varchar(max) 区别
SQL Server 2005之后版本:请使用 varchar(max).nvarchar(max) 和 varbinary(max) 数据类型,而不要使用 text.ntext 和 image 数据 ...
- 一脸懵逼学习Linux的Shell编程
1:什么是Shell??? (1)Shell是用户与内核进行交互操作的一种接口,目前最流行的Shell称为bash Shell(2)Shell也是一门编程语言<解释型的编程语言>,即she ...
- CentOS6 YUM安装MariaDB10.3.10
1.先新增加一个MariaDB.repo vi /etc/yum.repos.d/MariaDB.repo [mariadb] name = MariaDB baseurl = http://mirr ...
- MySQL的预处理技术
所谓的预处理技术,最初也是由MySQL提出的一种减轻服务器压力的一种技术! 传统mysql处理流程 1, 在客户端准备sql语句 2, 发送sql语句到MySQL服务器 3, 在MySQL服务器 ...