当前位置: 萬仟网 > IT编程>开发>PHP > php插入中文到sqlserver 2008里出现乱码的解决办法分享

php插入中文到sqlserver 2008里出现乱码的解决办法分享

2019年04月15日 23:24  | 萬仟网IT编程  | 我要评论
今天使用php操作数据库时发现插入sql server 2008数据库里的中文字段出现乱码,下面是我一开始时的一些情况:

开发环境是php5.3.3+apache2.2.17+sql server 2008,php脚本文件的编码是utf-8,传给数据库的编码是gb2312(sql server的默认字符编码可能是这个,我不肯定),我用的是微软官方提供的sqlsrv库来连接数据库的(ps:sql server 2005开始已经不支持用mssql.dll来连接了),故使用sqlsrv_query($conn, "set names gb2312");语句来设置传给数据库的编码格式的,sql语句这样写了:insert into opinion (content) values ('aaa中文内容');

运行这条sql语句,发现执行不成功,用sqlsrv_errors()函数来输出错误信息,得到如下结果:
复制代码 代码如下:

array ( [0] => array ( [0] => imssp [sqlstate] => imssp [1] => -46 [code] => -46 [2] => an error occurred translating the query string to utf-16: �ڶ��ֽڵ�Ŀ�����ҳ�у�û�д� unicode �ַ����ӳ�䵽���ַ� . [message] => an error occurred translating the query string to utf-16: �ڶ��ֽڵ�Ŀ�����ҳ�у�û�д� unicode �ַ����ӳ�䵽���ַ� . ) )

  这是在网页上显示的结果,上面的乱码是原封不动copy下来的。从 “an error occurred translating the query string to utf-16”可以看出是字符编码转换有问题导致的。于是我使用php的iconv函数来对中文进行强制编码转换,然后执行sql语句,代码如下:
复制代码 代码如下:

$string = iconv('utf-8', 'gb2312//ignore', 'aaa中文内容');
$sql = "insert into opinion (content) values ( $string)";
[code]
  这时候又报错了,错误信息如下:
[code]
array ( [0] => array ( [0] => 42s22 [sqlstate] => 42s22 [1] => 207 [code] => 207 [2] => [microsoft][sql server native client 10.0][sql server]���� 'aaa��������' ��ч�� [message] => [microsoft][sql server native client 10.0][sql server]���� 'aaa��������' ��ч�� ) )

  这个错误信息看不出什么头绪,我又把sql语句输出到网页上看一下是不是sql语句写错了,输出结果如下:
复制代码 代码如下:

insert into opinion (content) values ( aaa��������)

  咋一看好像没问题,其实是有问题的,注意到后面那个括号里的参数是应该用引号来括起来的(表示它是一个字符串),所以我又修改了sql语句,代码如下:
复制代码 代码如下:

$sql = "insert into opinion (content) values ( '".$string."')"; 为了看清楚我放大点


  用单引号把$string括起来,这样之后执行sql语句成功,并且数据库里保存的中文没有乱码。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

◎已有 0 人评论

Copyright © 2019  萬仟网 保留所有权利. 粤ICP备17035492号-1
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com