dqj96395 2013-02-13 06:46
浏览 43
已采纳

PHP mysqli stmt unicode scrambled

$HotelName = "Adams’ Inn";
$ID = 1;
$stmt = $sql->prepare("UPDATE coupons SET HotelName=? WHERE ID=?");
$stmt->bind_param("si",$HotelName,$ID);
$stmt->execute();

Output: Adams’ Inn

By the way, I have the following:

char set: utf8

collation: utf8_general_ci

  • 写回答

3条回答 默认 最新

  • duancaishi1897 2013-02-13 06:50
    关注

    checklist

    1. $sql->set_charset('utf8') right after connect.
    2. header('Content-Type: text/html; charset=utf-8'); before any output

    There are 2 sides involved - server and client. Client means PHP script, not HTTP client. And server needs to know what encoding does client expect.
    And you set only server side encoding, telling mysql in which encoding data have to be stored.
    But there is also a client.

    In fact, Mysql is great in recoding. As long as one encoding can be translated into other, Mysql can do it. For the different clients for example.
    It is not too much demanded nowadays, but this feature exists. So, Mysql need to know which encoding is supported by client. For this very purpose set_charset() function exists.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 对于知识的学以致用的解释
  • ¥50 三种调度算法报错 有实例
  • ¥15 关于#python#的问题,请各位专家解答!
  • ¥200 询问:python实现大地主题正反算的程序设计,有偿
  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败