


Mengapakah medan integer MySQL diambil sebagai rentetan dalam PHP?
Medan Integer MySQL Diambil sebagai Rentetan dalam PHP: Membongkar Penukaran
Apabila mengambil data daripada pangkalan data MySQL menggunakan PHP, anda mungkin menghadapi situasi yang membingungkan di mana medan integer dikembalikan sebagai rentetan. Tingkah laku yang tidak dijangka ini berpunca daripada sifat pengendalian data PHP.
Untuk memahami fenomena ini, pertimbangkan senario berikut:
// Query the database and retrieve the user's ID $result = $mysqli->query("SELECT userid FROM DB WHERE name='john'");
Andaikan pertanyaan berjaya mendapatkan semula ID pengguna, yang merupakan integer dalam pangkalan data, anda mungkin mengharapkan kod berikut untuk menyimpan nilai yang diambil sebagai integer pembolehubah:
$row = $result->fetch_assoc(); $id = $row['userid'];
Walau bagaimanapun, jika anda meneruskan untuk menyemak jenis data pembolehubah $id menggunakan gettype($id), anda akan terkejut apabila mendapati ia mengembalikan "rentetan".
Mengapa ini berlaku?
Inti isu terletak pada cara PHP mengendalikan data yang diambil daripada pangkalan data MySQL. Secara lalai, PHP menukar semua data yang diambil kepada rentetan, tanpa mengira jenis data asalnya dalam pangkalan data. Ini memastikan pengendalian data yang seragam, menjadikannya lebih mudah untuk aplikasi PHP diproses.
Menyelesaikan Isu
Beberapa kaedah boleh digunakan untuk menukar integer bertali rentetan kembali kepada jenis data integer yang dimaksudkan:
- Jenis Eksplisit Penghantaran: Menggunakan operator (int) atau fungsi intval():
$id = (int) $row['userid']; // Equivalent to intval($row['userid'])
- Pengisytiharan Jenis Data: Gunakan pernyataan AS MySQL dalam pertanyaan anda untuk menyatakan secara eksplisit jenis data medan yang dikembalikan:
$result = $mysqli->query("SELECT userid AS INT FROM DB WHERE name='john'");
Oleh dengan memasukkan salah satu daripada penyelesaian ini ke dalam kod anda, anda boleh memastikan bahawa medan integer yang diambil daripada pangkalan data MySQL anda dikendalikan dengan betul sebagai integer dalam aplikasi PHP anda.
Atas ialah kandungan terperinci Mengapakah medan integer MySQL diambil sebagai rentetan dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

11 skrip pemendek URL terbaik PHP (percuma dan premium)

Bekerja dengan Data Sesi Flash di Laravel

Bina aplikasi React dengan hujung belakang Laravel: Bahagian 2, React

Respons HTTP yang dipermudahkan dalam ujian Laravel

Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API REST

12 skrip sembang php terbaik di codecanyon

Pengumuman Penyiasatan Situasi PHP 2025
