Rumah >pangkalan data >tutorial mysql >Mengapa Sisipan Integer MySQL Saya Menunjukkan 2147483647 Daripada Nilai yang Betul?
Integer Salah Ditukar kepada 2147483647 Semasa Memasukkan MySQL?
Dalam dunia pengurusan pangkalan data, bukan perkara biasa untuk menghadapi situasi di mana data anda masukkan ke dalam jadual tidak sepadan dengan nilai yang anda maksudkan. Satu isu baru-baru ini menimbulkan kebimbangan tentang sisipan nilai integer yang salah (2147483647) ke dalam pangkalan data MySQL.
Mari kita lihat situasi ini dengan lebih dekat. Pengguna mempunyai pembolehubah yang dipanggil $steam64 yang mengandungi nilai integer yang sah mewakili ID Steam. Apabila mereka menggunakan coretan kod berikut untuk memasukkan nilai ini ke dalam pangkalan data MySQL, mereka bingung apabila mendapati integer yang sama sekali berbeza (2147483647) sedang disisipkan:
$sql_query = "INSERT INTO users_info (steam64) VALUES ('$steam64')";
Tingkah laku aneh ini membawa kepada kekeliruan dan kekecewaan . Usaha penyahpepijatan mendedahkan bahawa kedua-dua var_dump($steam64) dan menggemakan pembolehubah mengembalikan nilai integer yang betul, membuatkan pengguna tertanya-tanya apa yang telah berlaku.
Jawapan kepada misteri ini terletak pada jenis data lajur steam64 dalam jadual MySQL. Jenis data lalai untuk integer dalam MySQL ialah INT, yang mempunyai nilai maksimum 2147483647. Dalam kes ini, nilai yang disimpan dalam $steam64 melebihi nilai maksimum ini, mengakibatkan pemotongan bit tertib lebih tinggi dan sisipan yang terbesar integer boleh diwakili (2147483647).
Penyelesaian kepada isu ini adalah mudah: cuma tukar data jenis lajur steam64 dari INT ke BIGINT. Jenis data ini boleh menampung nilai integer yang lebih besar, memastikan nilai yang disimpan dalam $steam64 dimasukkan dengan betul ke dalam pangkalan data.
Atas ialah kandungan terperinci Mengapa Sisipan Integer MySQL Saya Menunjukkan 2147483647 Daripada Nilai yang Betul?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!