php mysq乱码的解决办法:1、通过“alter database 'test' default character set utf8 collate utf8_bin”语句修改数据库编码;2、通过“header(content-type:text/html; charset=utf-8)”语句设置页面字符集。
本教程操作环境:windows7系统、php8.1版、dell g3电脑。
php mysql乱码怎么办?
php+mysql乱码解决方案
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 数据库之后加多这一句
推荐学习:《php视频教程》
以上就是php mysql乱码怎么办的详细内容。