json_encode从MSSQL-SELECT生成JSON_ERROR_UTF8

时间:2013-08-15 06:57:48

标签: php sql-server json select special-characters

我对mssql的数据库查询有一个恼人的问题。如果结果包含像德语'ä'这样的特殊字符,我就不能使用 json_encode 将结果正确地作为json。

json_last_error 返回 5 ,等于 JSON_ERROR_UTF8 。我猜数据库不会返回 UTF-8 编码的值。数据库集合是* Latin1_General_CI_AS *,受影响的列是 varchars

php mssql.charset 配置无效。

我读过mysql用户可以使用mysql_query('SET CHARACTER SET utf8');正确编码返回值。我该怎么做才能正确获取mssql的值?

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

2 个答案:

答案 0 :(得分:11)

在JSON编码之前,请在字符串周围使用utf8_encode()

答案 1 :(得分:1)

您也可以在连接中设置此项:

$result = sqlsrv_connect($hostname, array(
    'UID' => $username,
    'PWD' => $password,
    'Database' => $database,
    "CharacterSet" => "UTF-8"   // <---- here the magic happens 
));

对我来说,这是更轻松的方式。