首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >php和mysql pdo中的重音

php和mysql pdo中的重音
EN

Stack Overflow用户
提问于 2014-05-02 08:01:08
回答 2查看 1.4K关注 0票数 0

我需要阅读DB中的一些以这种方式强调的值:“Cafeter圣保罗”,其中真正的单词是"Cafetería“。

当我将json传递给php脚本时,如下所示:

代码语言:javascript
复制
{"attribution":"Cafetería"} 

$json = file_get_contents('php://input');
$json_post = json_decode($json, true);
$attribution = $json_post['attribution'];

但是它读错了,没有给我任何来自DB的行。我使用PDO从DB读取。

代码语言:javascript
复制
$db = new PDO("mysql:host=$hostDB;dbname=$nameDB;charset=UTF-8", $userDB, $passwordDB, array(PDO::ATTR_EMULATE_PREPARES => false,
        PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));

    $stmt = $db->prepare("SELECT id, title, lat, lon FROM POI_Table WHERE attribution=:attribution");
    $stmt->execute(array(':attribution'=>$attribution));

如果我在HEIDI中执行相同的查询,但是按照json文件给出的值编写值,它就能工作。在查询中使用之前,我应该如何转换值?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-05-02 08:22:28

您正在为mysql设置错误的编码方式。

这是没有破折号的utf8

另一个答案本质上是错误的,因为它会导致双重额外的编码,并且只适用于lat1字符。

票数 0
EN

Stack Overflow用户

发布于 2014-05-02 08:10:13

在你的代码中做这个怎么样?

代码语言:javascript
复制
$json_post = json_decode(utf8_decode($json), true);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23423461

复制
相关文章

相似问题

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