首頁 >資料庫 >mysql教程 >如何修復 PDO 和 MySQL 中的 UTF-8 編碼問題?

如何修復 PDO 和 MySQL 中的 UTF-8 編碼問題?

Patricia Arquette
Patricia Arquette原創
2024-11-03 10:20:03604瀏覽

How to Fix UTF-8 Encoding Issues in PDO and MySQL?

PDO 和MySQL 中的UTF-8 編碼問題解釋

在PHP 中使用PDO 和MySQL 時,使用者可能會遇到插入UTF 的問題-8編碼資料存入資料庫。數據顯示為亂碼“?”插入時的字元。此問題源於缺乏正確的 UTF-8 字元集配置。

要解決此問題,在建立 PDO 連線後執行 SET NAMES 和 SET CHARACTER SET 查詢至關重要。但是,在某些情況下,僅靠這些查詢可能無法解決問題。

根據提供的答案,建議採用替代方法:

<code class="php">$pdo = new PDO(
    'mysql:host=hostname;dbname=defaultDbName',
    'username',
    'password',
    array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8")
);</code>

透過新增 PDO:: MYSQL_ATTR_INIT_COMMAND 選項,PDO 連線初始化期間強制使用 UTF-8。此方法透過確保資料庫連線從一開始就設定為UTF-8,有效解決了UTF-8編碼問題。

以上是如何修復 PDO 和 MySQL 中的 UTF-8 編碼問題?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn