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的面向对象编程
Oct 09 PHP
文章推荐系统(三)
Oct 09 PHP
php面向对象全攻略 (三)特殊的引用“$this”的使用
Sep 30 PHP
php array_search() 函数使用
Apr 13 PHP
php中通过虚代理实现延迟加载的实现代码
Jun 10 PHP
深入PHP curl参数的详解
Jun 17 PHP
ThinkPHP CURD方法之data方法详解
Jun 18 PHP
微信 开发生成带参数的二维码的实例
Nov 23 PHP
PHP+Ajax实现的无刷新分页功能详解【附demo源码下载】
Jul 03 PHP
thinkphp5.0自定义验证规则使用方法
Nov 16 PHP
PHP 使用二进制保存用户状态的实例
Jan 29 PHP
Thinkphp极验滑动验证码实现步骤解析
Nov 24 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
Apache+php+mysql在windows下的安装与配置图解(最新版)
2008/11/30 PHP
php处理json时中文问题的解决方法
2011/04/12 PHP
Laravel 5框架学习之Eloquent (laravel 的ORM)
2015/04/08 PHP
php解析mht文件转换成html的实例
2017/03/13 PHP
PHP实现函数内修改外部变量值的方法示例
2018/12/28 PHP
php设计模式之观察者模式定义与用法经典示例
2019/09/19 PHP
JQuery 操作Javascript对象和数组的工具函数小结
2010/01/22 Javascript
JavaScript中双叹号(!!)作用示例介绍
2014/04/10 Javascript
JS实现点击文字对应DIV层不停闪动效果的方法
2015/03/02 Javascript
javascript实现的固定位置悬浮窗口实例
2015/04/30 Javascript
JQuery插入DOM节点的方法
2015/06/11 Javascript
分享纯手写漂亮的表单验证
2015/11/19 Javascript
vue3.0 CLI - 2.4 - 新组件 Forms.vue 中学习表单
2018/09/14 Javascript
使用wxapp-img-loader自定义组件实现微信小程序图片预加载功能
2018/10/18 Javascript
Vue slot用法(小结)
2018/10/22 Javascript
解决vue的router组件component在import时不能使用变量问题
2020/07/26 Javascript
基于jquery实现彩色投票进度条代码解析
2020/08/26 jQuery
[01:06:42]VP vs NewBee Supermajor 胜者组 BO3 第二场 6.5
2018/06/06 DOTA
使用Python脚本实现批量网站存活检测遇到问题及解决方法
2016/10/11 Python
使用python和Django完成博客数据库的迁移方法
2018/01/05 Python
用Python下载一个网页保存为本地的HTML文件实例
2018/05/21 Python
CSS3 按钮边框动画的实现
2020/11/12 HTML / CSS
澳大利亚领先的女帽及配饰公司:Morgan&Taylor
2019/12/01 全球购物
教师敬业奉献模范事迹材料
2014/05/18 职场文书
民主生活会对照检查材料(统计局)
2014/09/21 职场文书
学校领导班子成员查摆问题及整改措施
2014/10/28 职场文书
2014年学校党建工作总结
2014/11/11 职场文书
2015年财务部工作总结
2015/04/10 职场文书
Python 中数组和数字相乘时的注意事项说明
2021/05/10 Python
python基础之模块的导入
2021/10/24 Python
继承Win10缺点!教你关闭Win11烦人的网络搜索
2021/11/23 数码科技
青岛市的收音机研制与生产
2022/04/07 无线电
golang生成并解析JSON
2022/04/14 Golang
Mysql索引失效 数据库表中有索引还是查询很慢
2022/05/15 MySQL
javascript中Set、Map、WeakSet、WeakMap区别
2022/12/24 Javascript