Heim >Datenbank >MySQL-Tutorial >Wie füge ich NULL-Werte aus PHP ordnungsgemäß in MySQL ein?

Wie füge ich NULL-Werte aus PHP ordnungsgemäß in MySQL ein?

DDD
DDDOriginal
2024-12-03 11:31:10967Durchsuche

How to Properly Insert NULL Values into MySQL from PHP?

PHP/MySQL-Nullwerte einfügen: Eine umfassende Lösung

MySQL-Datenbanken erlauben Nullwerte in verschiedenen Feldern. Allerdings kann das Einfügen von Nullwerten mit herkömmlichen PHP/MySQL-Abfragen problematisch sein, wenn einige Array-Werte null sind.

Problem:

In der bereitgestellten Abfrage:

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

Wenn $row['null_field'] null ist, führt dies zu einer leeren Spalte in Tabelle2 anstelle einer Null Wert.

Lösung: Vorbereitete Anweisungen

Die Verwendung von vorbereiteten Anweisungen mit der neueren MySQLi-Erweiterung bietet eine robuste Lösung:

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

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

$stmt->execute();

Vorteile der Verwendung von vorbereiteten Anweisungen:

  • Sie konvertieren Nullwerte automatisch in SQL NULL.
  • Sie verhindern SQL-Injection-Angriffe, indem sie Werte vor der Ausführung maskieren.
  • Sie vereinfachen die Parameterbindung und machen eine manuelle Verkettung von Abfrageparametern überflüssig.

Von Mithilfe vorbereiteter Anweisungen können Sie mühelos Nullwerte in MySQL-Datenbanken einfügen und potenzielle Probleme vermeiden, die bei herkömmlichen Abfragen auftreten.

Das obige ist der detaillierte Inhalt vonWie füge ich NULL-Werte aus PHP ordnungsgemäß in MySQL ein?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn