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


Posted in PHP onJuly 19, 2012

今天使用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下实现一个阿拉伯数字转中文数字的函数
Jul 10 PHP
php产生随机数的两种方法实例代码 输出随机IP
Apr 08 PHP
PHP通过session id 实现session共享和登录验证的代码
Jun 03 PHP
解析php中mysql_connect与mysql_pconncet的区别详解
May 15 PHP
php使用array_search函数实现数组查找的方法
Jun 12 PHP
thinkPHP中验证码的简单使用方法
Dec 26 PHP
PHP中key和current,next的联合运用实例分析
Mar 29 PHP
php遍历解析xml字符串的方法
May 05 PHP
php支付宝在线支付接口开发教程
Sep 19 PHP
PHP中静态变量的使用方法实例分析
Dec 01 PHP
php实现的后台表格分页功能示例
Oct 23 PHP
jQuery ajax+PHP实现的级联下拉列表框功能示例
Feb 12 PHP
php在项目中寻找代码的坏味道(综艺命名)
Jul 19 #PHP
PHP的5个安全措施小结
Jul 17 #PHP
php日期转时间戳,指定日期转换成时间戳
Jul 17 #PHP
UCenter 批量添加用户的php代码
Jul 17 #PHP
一个简单的网页密码登陆php代码
Jul 17 #PHP
采集邮箱的php代码(抓取网页中的邮箱地址)
Jul 17 #PHP
php生成静态文件的多种方法分享
Jul 17 #PHP
You might like
php4的session功能评述(三)
2006/10/09 PHP
使用NetBeans + Xdebug调试PHP程序的方法
2011/04/12 PHP
基于PHP文件操作的详细诠释
2013/06/21 PHP
PHP实现图片压缩的两则实例
2014/07/19 PHP
PHP常用处理静态操作类
2015/04/03 PHP
laravel实现按月或天或小时统计mysql数据的方法
2019/10/09 PHP
对象的类型:本地对象(1)
2006/12/29 Javascript
基于jquery扩展漂亮的下拉框可以二次修改
2013/11/19 Javascript
js 上下左右键控制焦点(示例代码)
2013/12/14 Javascript
node.js中的buffer.toJSON方法使用说明
2014/12/14 Javascript
js数组依据下标删除元素
2015/04/14 Javascript
.NET微信公众号开发之创建自定义菜单
2015/07/16 Javascript
JS截取字符串实例详解
2015/11/24 Javascript
confirm确认对话框的实现方法总结
2016/06/17 Javascript
JS作用域闭包、预解释和this关键字综合实例解析
2016/12/16 Javascript
JavaScript实现打印星型金字塔功能实例分析
2017/09/27 Javascript
深入理解vue中slot与slot-scope的具体使用
2018/01/26 Javascript
微信小程序实现上传图片裁剪图片过程解析
2019/08/22 Javascript
layui的select联动实现代码
2019/09/28 Javascript
vue中实现高德定位功能
2019/12/03 Javascript
[35:34]Liquid vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
python正则表达式面试题解答
2020/04/28 Python
Python+OpenCV目标跟踪实现基本的运动检测
2018/07/10 Python
python实现三次样条插值
2018/12/17 Python
python3反转字符串的3种方法(小结)
2019/11/07 Python
css3实现3D文本悬停改变效果的示例代码
2019/01/16 HTML / CSS
在IE6系列等老式浏览器中使用HTML5的新标签实现方案
2012/12/25 HTML / CSS
工业设计专业推荐信
2013/10/29 职场文书
《小白兔和小灰兔》教学反思
2014/02/18 职场文书
致长跑运动员加油稿
2014/02/20 职场文书
2015年助理工程师工作总结
2015/04/03 职场文书
人事行政助理岗位职责
2015/04/11 职场文书
校园安全主题班会
2015/08/12 职场文书
《詹天佑》教学反思
2016/02/20 职场文书
Python列表删除重复元素与图像相似度判断及删除实例代码
2021/05/07 Python
详解Nginx 被动检查服务器的存活状态
2021/10/16 Servers