php无法识别数据库中文 php无法连接数据库

高手求救,php调用mysql数据库不能显示中文呈乱码?

以前的国外主机用的Mysql是4.x系列的,感答尺消困仔觉还比较好,都无论GBK和UTF-8都没有乱码,没想到新的主机的Mysql是5.0版本的,导入数据后,用Php读出来全是问号,乱码一片,记得我以前也曾经有过一次切换出现乱码的经验,原因肯定是Mysql版清知本之间的差异问题。

创新互联建站专注于杭州企业网站建设,成都响应式网站建设,购物商城网站建设。杭州网站建设公司,为杭州等地区提供建站服务。全流程按需求定制网站,专业设计,全程项目跟踪,创新互联建站专业和态度为您提供的服务

只好查资料,发现了一个解决方法,就是在mysql_connect后面加一句SET

NAMES

UTF8,即可使得UTF8的数据库消除乱码,对于GBK的数据库则使用SET

NAMES

GBK,代码如下:

$mysql_mylink

=

mysql_connect($mysql_host,

$mysql_user,

$mysql_pass);

mysql_query("SET

NAMES

'GBK'");

我的php不能显示mysql数据库中的中文

你phpmyadmin也没设置好。把表整理为utf8-unicode-ci

,字段也是。连接校队也是。首先,要在phpmyadmin

显示正常。

下面这慎碧个是数据库输出时,网页显示乱码的处理。

mysql_query("set

name

xxx");

xxx

是你的网页游悔编码。

这句话放在SQL连接成功语句后。但是要在宽磨举SQL语句执行之前。

php操作数据库WHERE语句查询中文报错,无法读取数据?

MYSQL的字段名转义使用返引号`,不是单引号,注意上缓兄面代码的下面部分:

WHERE '账户'='中文'; //查询中文字报错,数字字母都能正常查询

【账户】是字段名,应使用反引号:

`账户`

【中文】是常量,单双引号都可以,但是要注意你现在的语句是扰拿袭在单引号里面,因此应该转义或者使用双引号,这部分可以修改为:

WHERE 账户="中文"';

另外,如果只是查询中文内容才报错,可能你粘贴代码和原始代码有区别,原始代码没有把字段名放在单引号里面,否则是查不到内容的。查询中文内容报错,一般是中敏胡文的编码和网页文件的编码、以及数据库的编码不一致,你这来数据库是UTF8,那么PHP脚本文件、浏览器网页都必须使用UTF-8


文章名称:php无法识别数据库中文 php无法连接数据库
文章分享:http://cdiso.cn/article/ddpejcp.html

其他资讯