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

2015-01-24信息快讯网

今天使用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语句成功,并且数据库里保存的中文没有乱码。
解析mysql 表中的碎片产生原因以及清理
PHP中mb_convert_encoding与iconv函数的深入解析
解析PHP中DIRECTORY_SEPARATOR,PATH_SEPARATOR两个常量的作用
解析coreseek for sphinx的使用
关于使用coreseek并为其做分页的介绍
解析php中array_merge与array+array的区别
关于查看MSSQL 数据库 用户每个表 占用的空间大小
Function eregi is deprecated (解决方法)
深入理解PHP中的Session和Cookie
PHP 使用MySQL管理Session的回调函数详解
解析CodeIgniter自定义配置文件
解析mysql left( right ) join使用on与where筛选的差异
sql注入与转义的php函数代码
基于AppServ,XAMPP,WAMP配置php.ini去掉警告信息(NOTICE)的方法详解
PHP中如何调用webservice的实例参考
Could not load type System.ServiceModel.Activation.HttpModule解决办法
php5.3中连接sqlserver2000的两种方法(com与ODBC)
php如何调用webservice应用介绍
ajax在joomla中的原生态应用代码
php在项目中寻找代码的坏味道(综艺命名)
UCenter 批量添加用户的php代码
PHP+Mysql日期时间如何转换(UNIX时间戳和格式化日期)
PHP中使用unset销毁变量并内存释放问题
PHP连接SQLServer2005的实现方法(附ntwdblib.dll下载)
apache+codeigniter 通过.htcaccess做动态二级域名解析
PHP连接SQLSERVER 注意事项(附dll文件下载)
深入了解 register_globals (附register_globals=off 网站打不开的解决方法)
SESSION信息保存在哪个文件目录下以及能够用来保存什么类型的数据
PHP Warning: PHP Startup: Unable to load dynamic library \ D:/php5/ext/php_mysqli.dll\
MySQL 日期时间函数常用总结
PHP Parse Error: syntax error, unexpected $end 错误的解决办法
在PHP中利用wsdl创建标准webservice的实现代码
PHP调用Webservice实例代码
关于php连接mssql:pdo odbc sql server
©2014-2024 dbsqp.com