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连mysql和oracle数据库性能比较
Oct 09 PHP
使用adodb lite解决问题
Dec 31 PHP
PHP编程函数安全篇
Jan 08 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十六)
Jun 30 PHP
php自定义hash函数实例
May 05 PHP
PHP按指定键值对二维数组进行排序的方法
Dec 22 PHP
PHP Try-catch 语句使用技巧
Feb 28 PHP
ThinkPHP实现更新数据实例详解(demo)
Jun 29 PHP
php PDO判断连接是否可用的实现方法
Apr 03 PHP
PHP使用pdo实现事务处理操作示例
Sep 05 PHP
Linux基于php-fpm模式的lamp搭建phpmyadmin的方法
Oct 25 PHP
PHP实现简易图形计算器
Aug 28 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检测文件编码的函数
2014/04/21 PHP
php项目开发中用到的快速排序算法分析
2016/06/25 PHP
php+ajax实现无刷新文件上传功能(ajaxuploadfile)
2018/02/11 PHP
php实现等比例压缩图片
2018/07/26 PHP
PHP切割整数工具类似微信红包金额分配的思路详解
2019/09/18 PHP
实例讲解Jquery中隐藏hide、显示show、切换toggle的用法
2016/05/13 Javascript
jQuery实现简单倒计时功能的方法
2016/07/04 Javascript
简单实现js页面切换功能
2021/01/10 Javascript
nodejs实现发出蜂鸣声音(系统报警声)的方法
2017/01/18 NodeJs
php简单数据库操作类的封装
2017/06/08 Javascript
原生js中ajax访问的实例详解
2017/09/19 Javascript
深入研究React中setState源码
2017/11/17 Javascript
jQuery与vue实现拖动验证码功能
2018/01/30 jQuery
深入学习JavaScript 高阶函数
2019/06/11 Javascript
JS开发 富文本编辑器TinyMCE详解
2019/07/19 Javascript
微信jssdk踩坑之签名错误invalid signature
2020/05/19 Javascript
精确查找PHP WEBSHELL木马的方法(1)
2011/04/12 Python
python3.3实现乘法表示例
2014/02/07 Python
Python程序设计入门(3)数组的使用
2014/06/16 Python
Python中的ctime()方法使用教程
2015/05/22 Python
Python判断字符串与大小写转换
2015/06/08 Python
python实现kNN算法
2017/12/20 Python
python3实现爬取淘宝美食代码分享
2018/09/23 Python
Python命名空间的本质和加载顺序
2018/12/17 Python
连接pandas以及数组转pandas的方法
2019/06/28 Python
Pycharm小白级简单使用教程
2020/01/08 Python
tensorflow之变量初始化(tf.Variable)使用详解
2020/02/06 Python
Keras - GPU ID 和显存占用设定步骤
2020/06/22 Python
网络编程中设计并发服务器,使用多进程与多线程,请问有什么区别?
2016/03/27 面试题
初中班主任评语大全
2014/04/24 职场文书
三好学生演讲稿范文
2014/04/26 职场文书
人力资源管理毕业求职信
2014/08/05 职场文书
2014年财务部工作总结
2014/11/11 职场文书
2014年办公室工作总结范文
2014/11/12 职场文书
Python基于百度API识别并提取图片中文字
2021/06/27 Python
golang 语言中错误处理机制
2021/08/30 Golang