Php json编码从MSSQL-SELECT生成json错误UTF8

Php json编码从MSSQL-SELECT生成json错误UTF8,php,sql-server,json,select,special-characters,Php,Sql Server,Json,Select,Special Characters,我对mssql的数据库查询有一个恼人的问题。如果结果包含特殊字符,如德语“ä”,则无法使用json_encode将结果正确地作为json json_last_error返回5,等于json_error_UTF8。我猜数据库不会返回UTF-8编码的值。数据库集合为*Latin1\u General\u CI\u AS*,受影响的列为varchars php mssql.charset配置无效 我听说mysql用户可以使用mysql\u查询('SET CHARACTER SET utf8')以正确编

我对mssql的数据库查询有一个恼人的问题。如果结果包含特殊字符,如德语“ä”,则无法使用json_encode将结果正确地作为json

json_last_error返回5,等于json_error_UTF8。我猜数据库不会返回UTF-8编码的值。数据库集合为*Latin1\u General\u CI\u AS*,受影响的列为varchars

php mssql.charset配置无效

我听说mysql用户可以使用
mysql\u查询('SET CHARACTER SET utf8')
以正确编码返回值。要正确获取mssql的值,我可以做什么


提示-我无法更改数据库中的任何内容。

在进行JSON编码之前,请在字符串周围使用
utf8\u encode()

您也可以在连接中设置:

$result = sqlsrv_connect($hostname, array(
    'UID' => $username,
    'PWD' => $password,
    'Database' => $database,
    "CharacterSet" => "UTF-8"   // <---- here the magic happens 
));
$result=sqlsrv\u connect($hostname,array)(
'UID'=>$username,
“PWD”=>$password,
“数据库”=>$Database,

“CharacterSet”=>“UTF-8”//在json_encode()之前尝试php的iconv()
utf8_encode
首先对数据进行编码。这是最好的解决方案。只需对结果进行整理并进行转换。感谢您的提示。