PHP-Einfach.de
  • PHP Tutorial
  • MySQL Tutorial
  • Für Fortgeschrittene
  • Webhosting
  • Forum

Codeschnipsel

Simple MYSQL INSERT und UPDATE

Zurück zur Übersicht
Diese beiden Funktionen machen aus einem Array einen INSERT oder UPDATE String.
Damit kann verhindert werden immer wieder Fehler in diesen Anweisungen zu haben.
Weiter unten noch die Erklärungen dazu.

function mysql_insert_string($table, array $data)
{
    $columns = array_map(function($col){return '`'.$col.'`';},array_keys($data));
    $values = array_map(function($val){
        if($val===null) return 'NULL';
        if(is_numeric($val)) return $val;
        return "'".$val."'";
    },$data);
    return "INSERT INTO `".$table."` (".implode(',',$columns).") VALUES (".implode(',',$values).")";
}
function mysql_update_string($table, array $data, $primary_key_column=null, $primary_key_value=null)
{
    array_walk($data, function(&$val, $key) {
        if($val===null) $val= 'NULL';
        elseif(!is_numeric($val)) $val = "'".$val."'";
        $val= "`".$key."`=".$val; });
    $where = null;
    if(!is_null($primary_key_column))
    {
        if(is_null($primary_key_value))
        {
            $symbol = 'IS';
            $value = 'NULL';
        }
        else
        {
            $symbol = '=';
            $value = is_numeric($primary_key_value)?$primary_key_value:"'".$primary_key_value."'";
        }
        $where = " WHERE `".$primary_key_column."` ".$symbol." ".$value;
    }
    return "UPDATE `".$table."` SET ".implode(',',$data).$where;
}



Angenommen man habe die Tabelle user mit den Spalten id, vorname, nachname, email in der Datenbank, so müsste man für ein insert folgende Arraystruktur aufbauen:
$insert = array('id'=>1, 'vorname'=>'test','nachname'=>null,'email'=>'[email protected]')

Die Keys bestimmen demnach die Tabellenspalte und der Wert des Arrays den Wert, der in die Datenbank eingetragen werden soll.
Der Parameter $table ist nun mit 'user' zu belegen.
Ein vollständiger Aufruf ginge so:
echo mysql_insert_string('user',array('id'=>1,'vorname'=>'test','nachname'=>null,'email'=>'[email protected]'));

Die Ausgabe ist:
Zitat:
INSERT INTO `user` (`id`,`vorname`,`nachname`,`email`) VALUES (1,'test',NULL,'[email protected]')



Bei einem Update verhält sich die Arraystruktur gleich. Lediglich ein Primary Key (wie in den meisten Tabellen die Spalte ID) und der dazugehörige Wert kann noch angegeben werden.
Ein update sähe so aus:
echo mysql_update_string('user',array('vorname'=>'test','nachname'=>null,'email'=>'[email protected]'),'id',1);

Hier wurde nun also die ID aus dem Array entfernt und hinten als zwei weitere Parameter angegeben.
Ausgabe:
Zitat:
UPDATE `user` SET `vorname`='test',`nachname`=NULL,`email`='[email protected]' WHERE `id` = 1


Beachte bitte, dass diese Funktionen nur den String zusammenbauen und das mysql(i)_query etc. nicht ausführen.


Kommentare

Autor Dreamwatcher

Zurück zur Übersicht
Autor: Nils Reimers
Zurück: URLs im Text identifizieren

Für Fortgeschrittene

  • Objektorientierte Programmierung
  • PHP Sicherheit
  • Script-Beispiele
  • Codeschnipsel
  • Stellenmarkt
Mit freundlicher Unterstützung von:
  • Punkt191 Werbeagentur
  • CasinoAndy Finland
  • Casinoohnelizenz.info
  • Cryptocasinomaster.com
  • CasinoHEX.at
  • inkedin.com

Hoster – Geringste Ausfallzeit

  1. webgo Ø 1 Min.
  2. Linevast Ø 2 Min.
  3. netcup Ø 3 Min.
  4. All-Inkl.com Ø 6 Min.
  5. checkdomain Ø 8 Min.
  6. dogado Ø 17 Min.
  7. bplaced Ø 17 Min.
  8. Contabo Ø 25 Min.
  9. Hetzner Ø 49 Min.
  10. ONE.com Ø 62 Min.
» Mehr erfahren

Impressum | Datenschutz | Auf PHP-Einfach.de werben

© PHP-Einfach.de 2003 - 2023

Cookie-Zustimmung verwalten
Um dir ein optimales Erlebnis zu bieten, verwenden wir Technologien wie Cookies, um Geräteinformationen zu speichern und/oder darauf zuzugreifen. Wenn du diesen Technologien zustimmst, können wir Daten wie das Surfverhalten oder eindeutige IDs auf dieser Website verarbeiten. Wenn du deine Zustimmung nicht erteilst oder zurückziehst, können bestimmte Merkmale und Funktionen beeinträchtigt werden.
Funktional Immer aktiv
Die technische Speicherung oder der Zugang ist unbedingt erforderlich für den rechtmäßigen Zweck, die Nutzung eines bestimmten Dienstes zu ermöglichen, der vom Teilnehmer oder Nutzer ausdrücklich gewünscht wird, oder für den alleinigen Zweck, die Übertragung einer Nachricht über ein elektronisches Kommunikationsnetz durchzuführen.
Vorlieben
Die technische Speicherung oder der Zugriff ist für den rechtmäßigen Zweck der Speicherung von Präferenzen erforderlich, die nicht vom Abonnenten oder Benutzer angefordert wurden.
Statistiken
Die technische Speicherung oder der Zugriff, der ausschließlich zu statistischen Zwecken erfolgt. Die technische Speicherung oder der Zugriff, der ausschließlich zu anonymen statistischen Zwecken verwendet wird. Ohne eine Vorladung, die freiwillige Zustimmung deines Internetdienstanbieters oder zusätzliche Aufzeichnungen von Dritten können die zu diesem Zweck gespeicherten oder abgerufenen Informationen allein in der Regel nicht dazu verwendet werden, dich zu identifizieren.
Marketing
Die technische Speicherung oder der Zugriff ist erforderlich, um Nutzerprofile zu erstellen, um Werbung zu versenden oder um den Nutzer auf einer Website oder über mehrere Websites hinweg zu ähnlichen Marketingzwecken zu verfolgen.
Optionen verwalten Dienste verwalten Anbieter verwalten Lese mehr über diese Zwecke
Einstellungen ansehen
{title} {title} {title}