php和mysql pdo中的口音

时间:2014-05-02 08:01:08

标签: php json pdo

我需要读取DB中的一些值,其中我有这样的口音:“CafeterÃa”,真正的单词是“Cafetería”

当我将json传递给php脚本时,它是这样的:

{"attribution":"Cafetería"} 

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

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

$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文件的方式编写值,则可以正常工作。在查询中使用之前如何转换值?

2 个答案:

答案 0 :(得分:0)

如何在代码中执行此操作?

$json_post = json_decode(utf8_decode($json), true);

答案 1 :(得分:0)

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

utf8 没有破折号

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