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 相关文章推荐
PR值查询 | PageRank 查询
Dec 20 PHP
PHP里的中文变量说明
Jul 23 PHP
php中批量修改文件后缀名的函数代码
Oct 23 PHP
php绘图中显示不出图片的原因及解决
Mar 05 PHP
让codeigniter与swfupload整合的最佳解决方案
Jun 12 PHP
微信公众平台之快递查询功能用法实例
Apr 14 PHP
详解js异步文件加载器
Jan 24 PHP
Json_encode防止汉字转义成unicode的方法
Feb 25 PHP
php自动载入类用法实例分析
Jun 24 PHP
PHP实现无限分类的实现方法
Nov 14 PHP
PHP实现数据库的增删查改功能及完整代码
Apr 18 PHP
eval(cmd)与eval($cmd)的区别与联系
Jul 07 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
PHP循环语句笔记(foreach,list)
2011/11/29 PHP
简单的php缓存类分享     php缓存机制
2014/01/22 PHP
php通过rmdir删除目录的简单用法
2015/03/18 PHP
Yii框架自定义数据库操作组件示例
2019/11/11 PHP
Nigma vs AM BO3 第一场2.13
2021/03/10 DOTA
用js计算页面执行时间的函数
2006/12/07 Javascript
对google个性主页的拖拽效果的js的完整注释[转]
2007/04/10 Javascript
js form action动态修改方法
2008/11/04 Javascript
jQuery选择头像并实时显示的代码
2010/06/27 Javascript
JSONP跨域GET请求解决Ajax跨域访问问题
2014/12/31 Javascript
jquery实现点击label的同时触发文本框点击事件的方法
2015/06/05 Javascript
全面解析bootstrap格子布局
2016/05/22 Javascript
使用JS组件实现带ToolTip验证框的实例代码
2017/08/23 Javascript
mui框架移动开发初体验详解
2017/10/11 Javascript
浅谈Node.js 沙箱环境
2018/05/15 Javascript
小程序Scroll-view上拉滚动刷新数据
2020/06/21 Javascript
浏览器JavaScript调试功能无法使用解决方案
2020/09/18 Javascript
[01:51]历届DOTA2国际邀请赛举办地回顾 TI9落地上海
2018/08/26 DOTA
Python 正则表达式操作指南
2009/05/04 Python
50行代码实现贪吃蛇(具体思路及代码)
2013/04/27 Python
python实现爬虫下载漫画示例
2014/02/16 Python
python3读取csv和xlsx文件的实例
2018/06/22 Python
Python 对输入的数字进行排序的方法
2018/06/23 Python
超简单的Python HTTP服务
2019/07/22 Python
Python中filter与lambda的结合使用详解
2019/12/24 Python
python add_argument()用法解析
2020/01/29 Python
html5使用canvas画一条线
2014/12/15 HTML / CSS
Hanro官网:奢华男士和女士内衣、睡衣和家居服
2018/10/25 全球购物
全球性的在线商店:Vogca
2019/05/10 全球购物
银行财务部实习生的自我鉴定
2013/11/27 职场文书
医药代表个人的求职信分享
2013/12/08 职场文书
文科毕业生自荐书范文
2014/04/17 职场文书
2014年班主任自我评价范文
2014/04/23 职场文书
工商管理专业毕业生求职信
2014/05/26 职场文书
Python基于Opencv识别两张相似图片
2021/04/25 Python
Python实现Hash算法
2022/03/18 Python