Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Memasukkan Nilai NULL dengan betul ke MySQL dari PHP?

Bagaimana untuk Memasukkan Nilai NULL dengan betul ke MySQL dari PHP?

DDD
DDDasal
2024-12-03 11:31:10967semak imbas

How to Properly Insert NULL Values into MySQL from PHP?

PHP/MySQL Insert Null Values: A Comprehensive Resolution

Pangkalan data MySQL membenarkan nilai nol dalam pelbagai medan. Walau bagaimanapun, memasukkan nilai nol menggunakan pertanyaan PHP/MySQL tradisional boleh menjadi masalah apabila beberapa nilai tatasusunan adalah batal.

Isu:

Dalam pertanyaan yang disediakan:

mysql_query("insert into table2 (f1, f2) values ('{$row['string_field']}', {$row['null_field']});")

Jika $row['null_field'] adalah batal, ia akan menghasilkan lajur kosong dalam jadual2 sebaliknya dengan nilai nol.

Penyelesaian: Penyata Disediakan

Menggunakan pernyataan yang disediakan dengan sambungan mysqli yang lebih baharu menawarkan penyelesaian yang mantap:

$stmt = $mysqli->prepare("INSERT INTO table2 (f1, f2) VALUES (?, ?)");
$stmt->bind_param('ss', $field1, $field2);

$field1 = "String Value";
$field2 = null;

$stmt->execute();

Kelebihan menggunakan pernyataan yang disediakan:

  • Ia secara automatik menukar null nilai kepada SQL NULL.
  • Mereka menghalang serangan suntikan SQL dengan melarikan diri dari nilai sebelum pelaksanaan.
  • Mereka memudahkan pengikatan parameter, menghilangkan keperluan untuk penggabungan manual parameter pertanyaan.

Dengan menggunakan pernyataan yang disediakan, anda boleh dengan mudah memasukkan nilai nol ke dalam pangkalan data MySQL dan mengelakkan masalah yang mungkin timbul timbul daripada pertanyaan tradisional.

Atas ialah kandungan terperinci Bagaimana untuk Memasukkan Nilai NULL dengan betul ke MySQL dari PHP?. 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