mysql+php中文显示乱码的解决
来源:互联网 发布:字中字软件 编辑:程序博客网 时间:2024/04/27 21:32
今天在做php 连接数据库的时候网页显示的就是乱码,弄的我都快疯掉了。终于解决了,mysql_query("set names utf8"); 这个utf8不是utf-8的,感谢提供帮助的http://hi.baidu.com/hacklzt/blog/item /3f3caf8adf9126779e2fb4ea.html
建议数据库用utf8编码
问题汇总:
1.mysql数据库默认的编码是utf8,如果这种编码与你的PHP网页不一致,可能就会造成MYSQL乱码.
2.MYSQL中创建表时会让你选择一种编码,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码.
3.MYSQL创建表时添加字段是可以选择编码的,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码.
4.用户提交页面的编码与显示数据的页面编码不一致,就肯定会造成PHP页面乱码.
5.如用户输入资料的页面是big5码, 显示用户输入的页面却是gb2312,这种100%会造成PHP页面乱码.
6.PHP页面字符集不正确.
7.PHP连接MYSQL数据库语句指定的编码不正确.
使用mysql+php产生乱码的原因都了解得很清楚了,那么解决就不困难了.
针对不同问题的解决方法:
1.mysql数据库默认的编码是utf8,如果这种编码与你的PHP网页不一致,可能就会造成MYSQL乱码.
修改数据库编码,如果是数据库编码不正确,可以在phpmyadmin 执行如下命令:
ALTER DATABASE 'test' DEFAULT CHARACTER SET utf8 COLLATE utf8_bin
以上命令就是将test数据库的编码设为utf8.
2.MYSQL中创建表时会让你选择一种编码,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码.
修改表的编码:
ALTER TABLE 'category' DEFAULT CHARACTER SET utf8 COLLATE utf8_bin
以上命令就是将一个表category的编码改为utf8.
3.MYSQL创建表时添加字段是可以选择编码的,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码.
修改字段的编码:
ALTER TABLE 'test' CHANGE 'dd' 'dd' VARCHAR( 45 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL
以上命令就是将test表中 dd的字段编码改为utf8.
4.用户提交页面的编码与显示数据的页面编码不一致,就肯定会造成PHP页面乱码.
如果是这种情况容易解决,只需检查下页面,修改源文件的charset即可.
5.如用户输入资料的页面是big5码, 显示用户输入的页面却是gb2312,这种100%会造成PHP页面乱码.
这种情况也是修改页面charset即可.
6.PHP页面字符集不正确.
为了避免PHP页面乱码的发生,PHP页面开始第一句
header("content-type:text/html; charset=utf-8");
//强行指定页面的编码,以避免乱码
7.PHP连接MYSQL数据库语句指定的编码不正确.
在连接数据库的语句中.
mysql_connect('localhost','user','password');
mysql_select_db('my_db');
mysql_query("set names utf8;"); //select 数据库之后加多这一句
- mysql+php中文显示乱码的解决
- php+mysql中文显示乱码解决
- 解决mysql显示中文乱码的问题
- php and mysql 中文乱码的解决
- [PHP]解决PHP和MySQL的中文乱码问题
- 解决MySQL中文乱码问题|PHP+MySQL
- 解决MySql数据库显示中文乱码的问题
- 解决mac下MySQL插入中文显示乱码的问题
- php调用mysql中文时显示乱码的解决方法
- php+mysql中文数据乱码问题的解决
- Struts+mysql解决显示中文乱码
- 解决mysql查询结果中文显示乱码
- 解决mysql 显示中文乱码问题
- 解决mysql命令行中显示中文乱码
- MySQL命令行中文显示乱码解决
- PHP MySQL中文内容显示乱码
- PHP读取MySQL显示中文乱码
- 解决PHP和MYSQL中文乱码问题
- HTML DOM Nodes
- 简单的jaxb例子
- Sub 与 Function 在VB程序设计中的区别
- 从Linux到Solaris(差别概览,命令差别)
- VB类与模块的区别
- mysql+php中文显示乱码的解决
- makefile的基本语法
- ssh免密码登陆问题Agent admitted failure to sign using the key
- [动态规划] hdu 3602-2012 和 USACO Section 3.4 Rockers
- 1022 Train Problem I
- opencv学习1
- windows2007 iis安装
- VC 树控件与列表控件的结合
- 从Linux到Solaris(系统安装,软件管理)