Mengendalikan Limpahan Integer untuk Storan PostgreSQL
Soalan pengaturcaraan ini melibatkan penukaran nilai fungsi cincang daripada uint64 kepada int64, dengan tumpuan khusus pada Keserasian PostgreSQL. PostgreSQL menyokong BIGINT (ditandatangani 64 bit), manakala fungsi hash murmur2 mengembalikan nilai uint64. Pengaturcara ingin menukar nilai ini dengan cekap untuk storan tanpa menjejaskan perwakilan binarinya.
Limpahan Integer Atas Tujuan: Penyelesaian
Untuk mencapai penukaran tanpa kehilangan data, penukaran jenis boleh digunakan. Coretan kod berikut menunjukkan penukaran ini:
i := uint64(0xffffffffffffffff) i2 := int64(i) fmt.Println(i, i2)
Pendekatan ini tidak mengubah perwakilan memori bagi nilai tetapi menukar jenisnya.
Perangkap dalam Penukaran Malar
Perhatikan bahawa percubaan untuk menukar pemalar integer yang tidak ditaip terus kepada int64 boleh membawa kepada masa penyusunan kesilapan. Pemalar integer yang tidak ditaip dengan ketepatan arbitrari tidak boleh ditugaskan terus kepada int64 jika ia melebihi nilai maksimumnya (0x7fffffffffffffff).
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menukar Nilai Hash uint64 dengan Selamat kepada int64 untuk Storan PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!