首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >json_encode从MSSQL生成JSON_ERROR_UTF8 -SELECT

json_encode从MSSQL生成JSON_ERROR_UTF8 -SELECT
EN

Stack Overflow用户
提问于 2013-08-15 14:57:48
回答 2查看 10.2K关注 0票数 7

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

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

php mssql.charset配置不起作用。

我读到mysql用户可以使用mysql_query('SET CHARACTER SET utf8');对返回值进行正确编码。要为mssql正确获取值,我可以做些什么?

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

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-08-15 15:52:25

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

票数 13
EN

Stack Overflow用户

发布于 2018-06-05 03:59:08

你也可以在你的连接中设置这个:

代码语言:javascript
复制
$result = sqlsrv_connect($hostname, array(
    'UID' => $username,
    'PWD' => $password,
    'Database' => $database,
    "CharacterSet" => "UTF-8"   // <---- here the magic happens 
));

对我来说,这是一种更简单的方式。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18247737

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档