1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > php插入中文到sqlserver 里出现乱码的解决办法分享【PHP】

php插入中文到sqlserver 里出现乱码的解决办法分享【PHP】

时间:2022-08-31 06:42:45

相关推荐

php插入中文到sqlserver 里出现乱码的解决办法分享【PHP】

后端开发|php教程

php,中文,乱码

后端开发-php教程

今天使用php操作数据库时发现插入SQL Server 数据库里的中文字段出现乱码,下面是我一开始时的一些情况:

html源码网页,ubuntu考文件太慢,本地的tomcat版本号,爬虫批量抢购,485接口如何与php通信,seo产品导航lzw

开发环境是php5.3.3+Apache2.2.17+SQL Server ,php脚本文件的编码是utf-8,传给数据库的编码是GB2312(SQL Server的默认字符编码可能是这个,我不肯定),我用的是微软官方提供的SQLSRV库来连接数据库的(PS:SQL Server 开始已经不支持用mssql.dll来连接了),故使用sqlsrv_query($conn, “set names GB2312”);语句来设置传给数据库的编码格式的,sql语句这样写了:insert into Opinion (content) values (‘aaa中文内容’);

php源码上传,ubuntu终端界面配置,python小说全站爬虫,php system,当阳seo外包lzw

运行这条sql语句,发现执行不成功,用sqlsrv_errors()函数来输出错误信息,得到如下结果:

一键加速网站源码,vscode怎样设置字体颜色,ubuntu aws时区,tomcat页面地址错误,vba 网络爬虫,php 用户 在线时长,昆明知名seo优化价格,DuckChat私有聊天网站,网站会员模板lzw

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语句成功,并且数据库里保存的中文没有乱码。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。