测试环境
--php8.2
--apache2.4
--sqlserver2022
一.PHP连接SQLSERVER中文乱码-【问题分析】编码问题
1、SQL语句中有中文会导致执行失败;
php连接sqlsever,输入中文,然后查询sqlserver中对应的数据,由于提交中文是UTF-8,而sqlserver的中文为GBK,所以字段无法匹配,没有查询结果。
2、查询结果有中文会显示乱码。
php连接sqlsever,读取数据表数据,由于sqlserver的中文为GBK,而读出来的中文是UTF-8,中文字符显示乱码。
3、打开查询分析器, 运行以下语句:
SELECT COLLATIONPROPERTY('Chinese_PRC_Stroke_CI_AI_KS_WS', 'CodePage')
运行,查看结果,显示“936”,说明该数据库的编码为GBK
附表,如下:
936 简体中文GBK
950 繁体中文BIG5
437 美国/加拿大英语
932 日文 949 韩文
866 俄文
65001

本文讲述了PHP8.2环境下连接SQLServer2022时遇到的中文乱码问题,主要原因是编码不一致。解决方法包括设置PHP文件编码为UTF-8,数据传输前后进行编码转换,以及使用iconv函数处理SQL查询和结果。
最低0.47元/天 解锁文章
908

被折叠的 条评论
为什么被折叠?



