加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php保存中文sql server 2008里发现乱码

发布时间:2022-02-18 01:17:54 所属栏目:PHP教程 来源:互联网
导读:今天使用php操作数据库时发现插入SQL Server 2008数据库里的中文字段出现乱码,下面是我一开始时的一些情况. 运行这条sql语句,发现执行不成功,用sqlsrv_errors()函数来输出错误信息,得到如下结果: Array ( [0] = Array ( [0] = IMSSP [SQLSTATE] = IMSSP [1
  今天使用php操作数据库时发现插入SQL Server 2008数据库里的中文字段出现乱码,下面是我一开始时的一些情况.
 
  运行这条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)";
 
  这时候又报错了,错误信息如下:
 
  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��������' ���� ) )
 
  
  参考其它的解决办法:
 
  若数据库的编码为GB2312,怎样在yii中进行配置才能使得页面的数据显示正常,并且数据库中的数据不能出现乱码.
 
  方法一:
 
  1. yii默认的编码方式是utf-8, 若想改变其编码方式需要在main.php文件中加上'charset'=>'GB2312', 这样才能改变函数的输出的编码方式
 
  2. sql server 2000 的编码方式默认为本地GB2312编码方式, 对数据库进行操作时要注意编码的方式
 
  3. web页面的编码相应的需要变为GB2312
 
  4. 文件保存时需要保存为GB2312编码,这样php文件中的中文字符才能正常解析
 
  方法二:
 
  1. 通过iconv函数对数据进行转码,代码如下:
 
  iconv('GB2312','UTF-8',$data)

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读