今天使用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语句成功,并且数据库里保存的中文没有乱码。
相关推荐:
ChatGPT显示“此网站无法加载站点”:背后原因与解决办法详解,用ai画明度渐变条
ChatGPT内部HTTP接口文档-为开发者提供高效便捷的AI服务接入方式,安屿ai
SEO与SEM策略:提升网站流量与品牌曝光的双剑合璧,ai补图
SEO武汉:如何提升武汉地区网站的搜索引擎排名,景区网站建设费用
AI提供的阅读书目对学生的专业知识有多大帮助,沃奇ai
seo简介主要写什么,seo主要内容 ,AI弧线这
AI撰写大数据解决方案:开启智能数据时代的新篇章,ai头号公敌
从语言助手到智能生活伙伴,未来的智能助手如何改变我们的生活,网站建设分站公司
求一个AI软件,彻底改变你的工作与生活!
仿写AI:智能时代的创作革命,洛江区移动房网站推广
亚马逊的seo是什么阿,亚马逊seo项目 ,中考用ai写作会判0分吗
ChatGPT198元永久会员,开启智慧之门,体验AI的极致服务!,老孙教ai
在线AI文章生成器开启智能创作新时代
ChatGPT当前不可用?如何应对AI服务中断的挑战,ai文章免费写作app
什么叫改写-解读“改写”背后的艺术与技巧,网站制作建设模板图片
揭开“好的AI软件”背后的秘密:让生活和工作更智能的利器
seo网站自学看什么书,seo技术适合自学吗 ,斑马ai阅读
SEO范例:如何通过优化提升网站流量,获取更多商机,广州抖音seo搜索广告
SEO添加:提升网站流量与排名的必备策略,seo团队成员中国人
SEO如何做?全方位解析提升网站排名的秘诀,AI翻译好处
ChatGPT支持多种语言输入输出,让全球资讯触手可及,联想拯救者的ai写作
WPJVX:开启数字化未来的智慧平台,关键词排名技术咨询乐云seo
ChatGPT怎么打不开了?揭秘背后的原因与解决方法,ai中打开ai文件丢失
SEO关键词利器:如何借助精准关键词提升网站流量与排名,ai绘画客户
seo线索收集是什么,seo线索收集是什么意思 ,ai生活ai童童
什么是seo伪原创,seo就业前景伪原创怎么写 ,头像ai画怎么弄
“爱站”:开启网站优化与流量增长的新纪元,seo入门ppt
ChatGPT您的应用遇到问题,无法正常启动?如何解决并重新体验智能助手的魅力!,男头ai关键词
为什么选择老域名注册,打造品牌价值的秘密武器,网站建设服务费用多少
Bing搜索不能预览了?搜索引擎的新变革与挑战,ai制作一张窗花
SEO选择:如何挑选最合适的SEO优化策略?,wb免费刷粉网站推广
AI免费生成文章的软件:轻松创作的秘密武器
SEO搜外:全球搜索引擎优化的秘密武器,如何选择网站建设类型呢
ChatGPT国内版:为中国用户量身定制的智能助手,开启AI新纪元,ai文章赚钱
AI仿写文章:开启内容创作新纪元
ChatGPT:人工智能对话新时代的领航者,ai音响华为还是小米好
为什么seo吸引人,为什么seo吸引人呢 ,ai路径查找器绘制树
ChatGPT暂时不可用?如何高效应对并寻找最佳替代方案!,logo ai教程视频
AI写作技巧,让创作事半功倍!
SEO检测,让网站排名飞升的秘密武器,高端快消食品营销推广
目前最火的AI软件有哪些?深度解析必备工具
什么是SEO可以自学吗,seo零基础可以自学吗 ,ai1紫
用AI优化文章,轻松提升内容质量与创作效率
SEO挣钱之道:如何通过SEO实现网络盈利,宁晋网站建设商家
AI自动帮写,轻松应对内容创作挑战,赋能写作新未来,嘿科技ai
seo用什么论坛引流,seo引流方法 ,ai写作续写神器
SEO新站优化指南:快速提升排名的必备技巧,海珠网站推广哪家有名
AI工具,让工作效率翻倍:AI工具教程全面解析
ChatGPT页面空白不乏登录:让你秒变职场高手与生活智囊,百度ai 腾讯ai
ChatGPT页面空白无法登录?如何解决这一困扰?,温州ai字幕生成