【已验证】解决PHP连接SQL Server时中文乱码问题23.11.04

测试环境

--php8.2

--apache2.4

--sqlserver2022

**一.PHP连接SQLSERVER中文乱码-【问题分析】**编码问题

1、SQL语句中有中文会导致执行失败;

php连接sqlsever,输入中文,然后查询sqlserver中对应的数据,由于提交中文是UTF-8,而sqlserver的中文为GBK ,所以字段无法匹配,没有查询结果

2、查询结果有中文会显示乱码。

php连接sqlsever,读取数据表数据,由于sqlserver的中文为GBK,而读出来的中文是UTF-8中文字符显示乱码

3、打开查询分析器, 运行以下语句:

sql 复制代码
SELECT  COLLATIONPROPERTY('Chinese_PRC_Stroke_CI_AI_KS_WS', 'CodePage')

运行,查看结果,显示"936",说明该数据库的编码为GBK

附表,如下:

sql 复制代码
936 简体中文GBK 
950 繁体中文BIG5 
437 美国/加拿大英语 
932 日文 949 韩文 
866 俄文 
65001 unicode UFT-8

编码问题:当数据从PHP应用程序传输到SQL Server时,如果编码不统一,就可能出现乱码问题。

二.开始解决问题-【解决方法】

第一,在php文件中添加下面代码,

php 复制代码
header("content-Type: text/html; charset=utf-8");

PHP文件保持默认UTF-8编码;

第二,进行输入数据的转码工作

当插入数据,或修改数据的时候,把utf-8,转为gbk,存入数据库。

当获取数据的时候,将数据 gbk转为utf-8。

2、查询前对SQL转码

当数据使用utf-8编码从PHP应用程序传输到SQL Server中时,如果SQL Server使用默认的GBK编码,则数据会出现乱码。
这时我们需要在PHP中使用iconv转换编码,确保数据以正确的编码传输到SQL Server中

这样,$sql 就是包含正确编码的字符串,我们可以将它插入到SQL Server中,然后可以顺利地查询出来了

接下来就可以用php函数iconv来对传入sql内的值进行中文转码处理:

php 复制代码
$sql = "SELECT '是'='是'"; 
$sql=iconv('UTF-8','GBK',$sql);

3、查询结果对含中文列转码

SQL Server会返回乱码。这是因为SQL Server中的表格或字段使用了GBK编码,

这时我们需要在PHP中使用iconv转换编码,gbk转为utf-8,确保数据以正确的编码传输到PHP应用程序中

php 复制代码
$stmt = sqlsrv_query( $conn, $sql);
if($stmt){
    while( $row = sqlsrv_fetch_array( $stmt, SQLSRV_FETCH_NUMERIC) ) {
        echo iconv('GBK','UTF-8',$row[0])."<br />";
    }
}
php 复制代码
 function str($str){
   $str=iconv ( "utf-8", "GBK", $str );
   return $str;
 }

$sql1 = "select * from sql_rvi_wx where name='".str("张三")."'";
相关推荐
彭于晏Yan1 小时前
MyBatis-Plus使用动态表名分表查询
java·开发语言·mybatis
MediaTea6 小时前
Python IDE:Spyder
开发语言·ide·python
不枯石6 小时前
Matlab通过GUI实现点云的均值滤波(附最简版)
开发语言·图像处理·算法·计算机视觉·matlab·均值算法
不枯石7 小时前
Matlab通过GUI实现点云的双边(Bilateral)滤波(附最简版)
开发语言·图像处理·算法·计算机视觉·matlab
二十雨辰7 小时前
vite如何处理项目中的资源
开发语言·javascript
聆风吟º8 小时前
远程录制新体验:Bililive-go与cpolar的无缝协作
开发语言·后端·golang
豆浆whisky9 小时前
netpoll性能调优:Go网络编程的隐藏利器|Go语言进阶(8)
开发语言·网络·后端·golang·go
蓝天白云下遛狗9 小时前
go环境的安装
开发语言·后端·golang
CAir29 小时前
go协程的前世今生
开发语言·golang·协程
@大迁世界9 小时前
Go 会成为“老生态”的新引擎吗?
开发语言·后端·golang