Rumah >pangkalan data >tutorial mysql >Mengapa Emoji Saya Tidak Menyimpan Betul dalam Pangkalan Data MySQL utf8mb4 Saya?

Mengapa Emoji Saya Tidak Menyimpan Betul dalam Pangkalan Data MySQL utf8mb4 Saya?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-10 14:16:11264semak imbas

Why Aren't My Emojis Saving Correctly in My MySQL utf8mb4 Database?

MySQL utf8mb4: Isu Semasa Menyimpan Emoji

Isu ini timbul apabila cuba menyimpan aksara Unicode, seperti emoji, ke dalam pangkalan data MySQL. Walaupun mengikut panduan dalam talian dan mengkonfigurasi pangkalan data, jadual dan lajur dengan betul, sesetengah emoji tidak disimpan dengan tepat.

Pengesahan Konfigurasi

Untuk memastikan konfigurasi yang betul, set aksara dan pengumpulan pangkalan data, jadual dan lajur hendaklah ditetapkan kepada utf8mb4 (_unicode_ci). Selain itu, pastikan pembolehubah khusus pangkalan data berikut ditetapkan kepada utf8mb4: character_set_client, character_set_connection dan character_set_results.

Pelarasan Pembolehubah Khusus Pangkalan Data

Jika pembolehubah ini tidak ditetapkan dengan betul untuk pangkalan data tertentu, MySQL mungkin tidak dapat menyimpan emoji. Untuk melaraskan tetapan ini, seseorang boleh melaksanakan pertanyaan:

UBAH PANGKALAN DATA pangkalan data_nama SET KARAKTER = utf8mb4, COLLATE = utf8mb4_unicode_ci;

my.cnf Konfigurasi FailSelain itu, pastikan baris berikut hadir fail konfigurasi my.cnf:

[mysql]
default-character-set = utf8mb4

[mysqld]
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
Pertimbangan Tambahan

Jika pertanyaan SET NAMES utf8mb4 dilaksanakan, ketiga-tiga pembolehubah khusus pangkalan data (set_karakter , _connection, dan _results) akan ditetapkan dengan betul.
  • Emoji yang panjangnya hanya 3 bait boleh disimpan menggunakan pengekodan utf8, menerangkan sebab emoji matahari disimpan dengan betul.

Atas ialah kandungan terperinci Mengapa Emoji Saya Tidak Menyimpan Betul dalam Pangkalan Data MySQL utf8mb4 Saya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn