如何解决php insert mysql乱码问题

php insert mysql乱码的解决办法:1、将php页面保存为UTF-8的编码格式;2、用UTF8格式进行数据提交;3、在数据库中设置“ENGINE=MyISAM DEFAULT CHARSET=utf8;”。

本文操作环境:Windows7系统,PHP7.1版,Dell G3电脑。

如何解决php insert mysql乱码问题?

php插入到mysql数据库中文乱码问题解决

今天重装了系统重新安装了PHP的运行环境,也没注意太多,想写点东西复习复习……当我用INSERT INTO想数据表里添加数据的时候,发现数据只要是中文的都是以乱码显示的,于是我在网页中规定了语言为gbk发现还是不行,在网上查了半天做了一下总结:

1.php页面要保存为UTF-8的编码格式。

2.php在数据提交的是要用UTF8。

3.MYSQL创建表的时候要用ENGINE=MyISAM DEFAULT CHARSET=utf8;

举例(由于我懒得写,网上的这个例子感觉还挺清楚的):

建表:

Create TABLE `net_city` (
`cityid` smallint(4) NOT NULL auto_increment,
`cityname` varchar(80) NOT NULL default '',
`provinceid` smallint(2) NOT NULL default '0',
`inarea` varchar(5000) NOT NULL default '',
`outarea` varchar(5000) NOT NULL default '',
`tel` varchar(400) NOT NULL default '',
PRIMARY KEY (`cityid`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

PHP里的代码:

$conn=mysql_connect(localhost, 用户名, 密码);
mysql_query(set names 'utf8',$conn);
mysql_select_db(数据名,$conn);
$exec=insert into net_city (cityname,inarea,outarea,tel) values ('.$link_cityname.','.$link_inarea.','.$link_outarea.','.$link_tel.');
$result=mysql_query($exec,$conn);
if($result){
       echo 1;
     }else{
        echo 0;
     }
mysql_close($conn);

后来我试了试全部都用成gbk的,也是可以的~

推荐学习:《PHP教程

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...