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

 更新时间:2012年07月19日 13:07:14   作者:  
今天使用php操作数据库时发现插入SQL Server 2008数据库里的中文字段出现乱码,通过下面的方法解决了,需要的朋友可以参考下
今天使用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语句成功,并且数据库里保存的中文没有乱码。

相关文章

  • PHP 中文处理技巧

    PHP 中文处理技巧

    做AJAX应用或Flash应用,提交中文内容到后台,涉及到编码解码(encode、decode)及编码格式的转换。
    2010-04-04
  • php多个文件及图片上传实例详解

    php多个文件及图片上传实例详解

    这篇文章主要介绍了php多个文件及图片上传的方法,以实例形式详细叙述了多文件上传的原理与实现技巧,非常实用,需要的朋友可以参考下
    2014-11-11
  • PHP实现在对象之外访问其私有属性private及保护属性protected的方法

    PHP实现在对象之外访问其私有属性private及保护属性protected的方法

    这篇文章主要介绍了PHP实现在对象之外访问其私有属性private及保护属性protected的方法,简单介绍了php public、private及protected的功能及用法,并结合实例形式分析了php在对象之外访问其私有属性private及保护属性protected的方法,需要的朋友可以参考下
    2017-11-11
  • PHP自定义函数获取搜索引擎来源关键字的方法

    PHP自定义函数获取搜索引擎来源关键字的方法

    这篇文章主要介绍了PHP自定义函数获取搜索引擎来源关键字的方法,涉及php针对来路页面URL的分析与判断技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • php调用nginx的mod_zip模块打包ZIP文件

    php调用nginx的mod_zip模块打包ZIP文件

    这篇文章主要介绍了php调用nginx的mod_zip模块打包ZIP文件,需要的朋友可以参考下
    2014-06-06
  • PHP的runkit扩展如何使用

    PHP的runkit扩展如何使用

    PHP 运行的时候,也就是部署完成后,我们是不能修改常量的值,也不能修改方法体内部的实现的。也就是说,我们编码完成后,将代码上传到服务器,这时候,我们想在不修改代码的情况去修改一个常量的值是不行的。但是,runkit 扩展却可以帮助我们完成这个功能。
    2021-05-05
  • php插件功能实现方法介绍

    php插件功能实现方法介绍

    这篇文章主要介绍了php插件功能实现方法,主要包括php开发插件使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下
    2022-11-11
  • Smarty模板学习笔记之Smarty简介

    Smarty模板学习笔记之Smarty简介

    Smarty是一个使用PHP写出来的模板PHP模板引擎,是目前业界最著名的PHP模板引擎之一。它分离了逻辑代码和外在的内容,提供了一种易于管理和使用的方法,用来将原本与HTML代码混杂在一起PHP代码逻辑分离。
    2014-05-05
  • 解析php中获取系统信息的方法

    解析php中获取系统信息的方法

    本篇文章是对php中获取系统信息的方法进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • php防止用户重复提交表单

    php防止用户重复提交表单

    这篇文章主要介绍了解决php表单重复提交实现方法,需要的朋友可以参考下
    2015-11-11

最新评论