Rumah >pangkalan data >tutorial mysql >Menyimpan Hashes SHA1 dalam MySQL: BINARY(20) atau VARCHAR(40)?

Menyimpan Hashes SHA1 dalam MySQL: BINARY(20) atau VARCHAR(40)?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-20 20:11:18798semak imbas

 Storing SHA1 Hashes in MySQL: BINARY(20) or VARCHAR(40)?

Menyimpan Nilai Hash SHA1 dalam MySQL: Berapa Lama Patut Jadi Medan VARCHAR?

Apabila menyimpan hasil cincang SHA1 dalam MySQL pangkalan data, adalah penting untuk menentukan panjang medan VARCHAR yang sesuai. Nilai SHA1 adalah 160 bit panjang, jadi ia harus disimpan dalam medan yang boleh menampung panjang ini.

Artikel itu menentang penggunaan medan VARCHAR untuk menyimpan nilai cincang SHA1 kerana ia membazirkan bait tambahan untuk panjang daripada medan panjang tetap. Sebaliknya, ia mengesyorkan menggunakan medan BINARI(20), yang sepanjang 20 aksara dan boleh menyimpan nilai SHA1 160-bit tanpa membuang ruang.

Selain itu, artikel mencadangkan menggunakan fungsi UNHEX untuk menukar SHA1 nilai kepada binari sebelum menyimpannya dalam medan BINARI. Ini mengurangkan keperluan storan berbanding dengan menyimpan nilai mentah SHA1.

Artikel diakhiri dengan membandingkan keperluan storan untuk medan BINARY(20) dan CHAR(40). Untuk sejuta rekod, BINARY(20) memerlukan kurang ruang daripada CHAR(40) apabila menggunakan enjin InnoDB.

Atas ialah kandungan terperinci Menyimpan Hashes SHA1 dalam MySQL: BINARY(20) atau VARCHAR(40)?. 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