Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Mengoptimumkan Storan UUID Menggunakan Pengekodan Base64?

Bagaimanakah Saya Boleh Mengoptimumkan Storan UUID Menggunakan Pengekodan Base64?

Barbara Streisand
Barbara Streisandasal
2024-12-20 09:52:10362semak imbas

How Can I Optimize UUID Storage Using Base64 Encoding?

Storan UUID Dioptimumkan Menggunakan Base64

Pendekatan asal untuk menukar UUID kepada base64 dan mengalih keluar trailing "==" menghasilkan 22-bait rentetan. Walaupun ini merupakan teknik penjimatan ruang, ia berpotensi menjejaskan kebolehbacaan dan keserasian UUID.

Pendekatan yang lebih mantap melibatkan penggunaan perpustakaan UUID yang menyokong penukaran UUID kepada perwakilan base64 padat. Perpustakaan sedemikian mengekodkan bit UUID yang paling dan paling kurang penting ke dalam rentetan base64 tanpa sebarang padding atau aksara mengekor yang tidak perlu. Kaedah ini biasanya menghasilkan rentetan sekitar 26-30 aksara sambil mengekalkan format UUID yang boleh dibaca manusia.

Contoh perpustakaan sedemikian ialah Apache Commons Codec, yang menyediakan fungsi berikut:

import org.apache.commons.codec.binary.Base64;

private static String uuidToBase64(String str) {
    Base64 base64 = new Base64();
    UUID uuid = UUID.fromString(str);
    ByteBuffer bb = ByteBuffer.wrap(new byte[16]);
    bb.putLong(uuid.getMostSignificantBits());
    bb.putLong(uuid.getLeastSignificantBits());
    return base64.encodeBase64URLSafeString(bb.array());
}

private static String uuidFromBase64(String str) {
    Base64 base64 = new Base64(); 
    byte[] bytes = base64.decodeBase64(str);
    ByteBuffer bb = ByteBuffer.wrap(bytes);
    UUID uuid = new UUID(bb.getLong(), bb.getLong());
    return uuid.toString();
}

Menggunakan pendekatan ini, anda boleh menukar UUID kepada rentetan base64 dengan kiraan bait yang dikurangkan sambil mengekalkan integriti dan keserasian.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengoptimumkan Storan UUID Menggunakan Pengekodan Base64?. 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