测试环境
--php8.2
--apache2.4
--sqlserver2022
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 unicode UFT-8
编码问题:当数据从PHP应用程序传输到SQL Server时,如果编码不统一,就可能出现乱码问题。
第一,在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内的值进行中文转码处理:
- $sql = "SELECT '是'='是'";
- $sql=iconv('UTF-8','GBK',$sql);
3、查询结果对含中文列转码
SQL Server会返回乱码。这是因为SQL Server中的表格或字段使用了GBK编码,
这时我们需要在PHP中使用iconv转换编码,gbk转为utf-8,确保数据以正确的编码传输到PHP应用程序中
- $stmt = sqlsrv_query( $conn, $sql);
- if($stmt){
- while( $row = sqlsrv_fetch_array( $stmt, SQLSRV_FETCH_NUMERIC) ) {
- echo iconv('GBK','UTF-8',$row[0])."
"; - }
- }
- function str($str){
- $str=iconv ( "utf-8", "GBK", $str );
- return $str;
- }
-
- $sql1 = "select * from sql_rvi_wx where name='".str("张三")."'";