Heim > Backend-Entwicklung > PHP-Tutorial > Wie vermeide ich MySQL-Fehler beim Einfügen von Daten mit einfachen Anführungszeichen in PHP?

Wie vermeide ich MySQL-Fehler beim Einfügen von Daten mit einfachen Anführungszeichen in PHP?

Patricia Arquette
Freigeben: 2024-11-01 16:25:02
Original
703 Leute haben es durchsucht

How to Avoid MySQL Errors When Inserting Data Containing Single Quotes in PHP?

Einfache Anführungszeichen in PHP-MySQL-Einfügungen maskieren

Hintergrund:

Bei MySQL-Abfragen werden Zeichenfolgen verwendet, die Sonderzeichen enthalten können. wie einfache Anführungszeichen. Diese Sonderzeichen müssen maskiert werden, um zu verhindern, dass MySQL sie als Teil der Abfrage falsch interpretiert.

Problem:

Ein Entwickler stößt auf ein Problem beim Einfügen von Daten in eine MySQL-Datenbank schlägt aufgrund eines einfachen Anführungszeichens fehl und löst einen MySQL-Fehler aus. Das Problem tritt bei einer zweiten Abfrage auf, bei der Daten aus der Datenbank abgerufen und in einer E-Mail-Vorlage verwendet werden.

Ursache und Lösung:

Der Schuldige ist das Fehlen angemessener Informationen Escapezeichen beim Einfügen von Daten in MySQL. Die zweite Abfrage ruft Daten aus der Datenbank ab, die einfache Anführungszeichen enthalten können. Diese einfachen Anführungszeichen werden bei Verwendung in der E-Mail-Vorlage nicht maskiert, was zum MySQL-Fehler führt.

Um dieses Problem zu beheben, verwenden Sie mysql_real_escape_string(), um alle Zeichenfolgen zu maskieren, bevor Sie sie in MySQL einfügen. Diese Funktion maskiert Sonderzeichen, einschließlich einfacher Anführungszeichen. Durch die Verwendung dieser Funktion funktionieren beide Abfragen korrekt, unabhängig davon, ob in den Daten einfache Anführungszeichen vorhanden sind.

<code class="php">$escaped_order_id = mysql_real_escape_string($order_id);
$escaped_message_content = mysql_real_escape_string($message_content);

$result = mysql_query("INSERT INTO job_log
(order_id, supplier_id, category_id, service_id, qty_ordered, customer_id, user_id, salesperson_ref, booking_ref, booking_name, address, suburb, postcode, state_id, region_id, email, phone, phone2, mobile, delivery_date, stock_taken, special_instructions, cost_price, cost_price_gst, sell_price, sell_price_gst, ext_sell_price, retail_customer, created, modified, log_status_id)
VALUES
('$escaped_order_id', '$supplier_id', '$category_id', '{$value['id']}', '{$value['qty']}', '$customer_id', '$user_id', '$salesperson_ref', '$booking_ref', '$booking_name', '$address', '$suburb', '$postcode', '$state_id', '$region_id', '$email', '$phone', '$phone2', '$mobile', STR_TO_DATE('$delivery_date', '%d/%m/%Y'), '$stock_taken', '$special_instructions', '$cost_price', '$cost_price_gst', '$sell_price', '$sell_price_gst', '$ext_sell_price', '$retail_customer', '".date('Y-m-d H:i:s', time())."', '".date('Y-m-d H:i:s', time())."', '1')");

$query = mysql_query("INSERT INTO message_log
(order_id, timestamp, message_type, email_from, supplier_id, primary_contact, secondary_contact, subject, message_content, status)
VALUES
('$escaped_order_id', '".date('Y-m-d H:i:s', time())."', '$email', '$from', '$row->supplier_id', '$row->primary_email' ,'$row->secondary_email', '$subject', '$escaped_message_content', '1')");</code>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie vermeide ich MySQL-Fehler beim Einfügen von Daten mit einfachen Anführungszeichen in PHP?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage