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 相关文章推荐
最省空间的计数器
Oct 09 PHP
打造计数器DIY三步曲(上)
Oct 09 PHP
在mysql数据库原有字段后增加新内容
Nov 26 PHP
PHP 获取目录下的图片并随机显示的代码
Dec 28 PHP
php从数组中随机抽取一些元素的代码
Nov 05 PHP
PHP容易忘记的知识点分享
Apr 30 PHP
php中引用符号(&)的使用详解
Nov 13 PHP
php中mail函数发送邮件失败的解决方法
Dec 24 PHP
php生成curl命令行的方法
Dec 14 PHP
PHP缩略图生成和图片水印制作
Jan 07 PHP
highchart数据源纵轴json内的值必须是int(详解)
Feb 20 PHP
PHP使用两个栈实现队列功能的方法
Jan 15 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
一个简单的自动发送邮件系统(三)
2006/10/09 PHP
PHP+Mysql+jQuery中国地图区域数据统计实例讲解
2015/10/10 PHP
windows server 2008/2012安装php iis7 mysql环境搭建教程
2016/06/30 PHP
在JavaScript中通过URL传递汉字的方法
2007/04/09 Javascript
页面版文本框智能提示JS代码
2009/11/20 Javascript
JS实现的打字机效果完整实例
2016/06/20 Javascript
jQuery实现的无缝广告图片左右滚动功能详解
2016/12/24 Javascript
JavaScript实现移动端页面按手机屏幕分辨率自动缩放的最强代码
2017/08/18 Javascript
ES6解构赋值的功能与用途实例分析
2017/10/31 Javascript
vue addRoutes实现动态权限路由菜单的示例
2018/05/15 Javascript
详解微信小程序支付流程与梳理
2019/07/16 Javascript
Vue中keep-alive的两种应用方式
2020/07/15 Javascript
vue-cli3自动消除console.log()的调试信息方式
2020/10/21 Javascript
Python中os和shutil模块实用方法集锦
2014/05/13 Python
分享一下Python数据分析常用的8款工具
2018/04/29 Python
用python给自己做一款小说阅读器过程详解
2019/07/11 Python
python的移位操作实现详解
2019/08/21 Python
Python偏函数Partial function使用方法实例详解
2020/06/17 Python
python中关于数据类型的学习笔记
2020/07/19 Python
Python3爬虫关于识别检验滑动验证码的实例
2020/07/30 Python
使用jupyter notebook运行python和R的步骤
2020/08/13 Python
Python实现迪杰斯特拉算法过程解析
2020/09/18 Python
对Pytorch 中的contiguous理解说明
2021/03/03 Python
Clarria化妆品官方网站:购买天然和有机化妆品系列
2018/04/08 全球购物
美国在线自行车商店:Jenson USA
2018/05/22 全球购物
系统管理员的职责包括那些?管理的对象是什么?
2013/01/18 面试题
行政专员岗位职责
2014/01/02 职场文书
给儿子的表扬信
2014/01/15 职场文书
2014年教师节演讲稿
2014/09/03 职场文书
教师党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
工作作风建设心得体会
2014/10/22 职场文书
私用公车造成事故检讨书
2014/11/16 职场文书
工作自我推荐信范文
2015/03/25 职场文书
签订劳动合同通知书
2015/04/16 职场文书
2015年计生工作总结范文
2015/04/24 职场文书
我家女友可不止可爱呢 公开OP主题曲无字幕动画MV
2022/04/11 日漫