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

Crashkurs MySQL

15. Juli 2019
  1. Home
  2. »
  3. MySQL Tutorial
  4. »
  5. Crashkurs MySQL

In PHP existieren drei Varianten um auf eine MySQL Datenbank zugreifen. Die älteste nutzt die MySQL Erweiterung , die aber seit PHP 5.5.0 als veraltet (deprecated) markiert wurde und in PHP 7 vollständig entfernt wurde. Die zweite Möglichkeit ist mittels der MySQL Improved Extension (MySQLi) und die letzte Möglichkeit ist mittels PHP Data Objects (PDO) .

Dieser Artikel ist ein Crashkurs über die veraltete MySQL Erweiterung die nicht mehr verwendet werden sollte. Möchtet ihr eine umfassende Einführung in MySQL, so empfehlen wir euch unser MySQL Tutorial. Falls ihr die Grundlagen bereits beherrscht, dann kann für euch unser  PDO Crashkurs oder MySQLi Crashkurs interessant sein.

Inhaltsverzeichnis

  • 1 Verbindung aufbauen
  • 2 SQL Query an Datenbank senden
  • 3 Datensätze abrufen
  • 4 Prepared Statements
  • 5 Anzahl der Zeilen
  • 6 Eingefügte ID
  • 7 MySQL Fehlermeldung

Verbindung aufbauen

Eine Verbindung zur Datenbank kann wie folgt aufgebaut werden:

1
2
3
4
5
6
<?php
mysql_connect ("Servername", "Username", "Passwort")
or die ("keine Verbindung möglich. Benutzername oder Passwort sind falsch");
 
mysql_select_db("Datenbankenname") or die ("Die Datenbank existiert nicht.");
?>

SQL Query an Datenbank senden

Um einen SQL-Query an die Datenbank zu senden, wird die Funktion mysql_query($sql) verwendet:

1
2
3
4
<?php
$sql = "UPDATE tabelle SET spalte1 = 'Wert1' WHERE id = 1";
mysql_query($abfrage);
?>

Datensätze abrufen

Zum Abruf von Datensätzen die ihr mittels SELECT-Query erhalten habt existieren die Funktionen mysql_fetch_assoc($sql) und mysql_fetch_object($sql) :

1
2
3
4
5
6
7
8
9
10
11
12
13
<?php
$sql= "SELECT * FROM tabelle";
$result = mysql_query($abfrage);
while($row = mysql_fetch_assoc($result)) {
   echo $row['spaltenname'];
}
 
//Mittels mysql_fetch_object
$result = mysql_query($abfrage);
while($row = mysql_fetch_object($result)) {
   echo $row->spaltenname;
}
?>

Prepared Statements

Prepared Statements stehen bei der veralteten MySQL-Schnittstellen nicht zur Verfügung. Stattdessen müssen Parameter in den SQL-Query eingebunden werden. Um ein Schutz vor SQL-Injections zu bieten, sollte die Funktion mysql_real_escape_string($string) genutzt werden.

1
2
3
4
5
6
<?php
$value = 'Wert';
$sql = "SELECT * FROM tabelle WHERE spalte = '".mysql_real_escape_string($value)."' ORDER BY id";
$result = mysql_query($sql);
//....
?>

Anzahl der Zeilen

Die Anzahl der betroffenen Zeilen eines SQL-Queries erhält man mittels mysql_num_rows($result) :

1
2
3
4
5
6
<?php
$sql= "SELECT * FROM tabelle";
$result = mysql_query($sql);
$count = mysql_num_rows($result);
echo $count;
?>

Eingefügte ID

Um die vergebene Auto Increment-ID eines INSERT-Queries zu erhalten existiert die Funktion mysql_insert_id() .

1
2
3
4
5
6
<?php
$sql = "INSERT INTO tabelle (spalte1, spalte2) VALUES ('wert1', 'wert2')";
mysql_query($sql);
$id = mysql_insert_id();
echo $id;
?>

MySQL Fehlermeldung

Falls ein Query fehlerhaft ist, lässt sich mittels mysql_error() die Fehlermeldung abrufen:

1
2
3
4
<?php
$sql = "SELECT * FROM tabelle";
$result = mysql_query($sql) or die(mysql_error());
?>

 

Autor: Nils Reimers
Zurück: Übersicht SQL-Befehle
Weiter: Crashkurs MySQLi

MySQL Tutorial

  • MySQL installieren und starten
  • phpMyAdmin
  • Verbindung aufbauen
  • Simple Datenabfrage
  • Komplexere Datenabfrage
  • Prepared Statements
  • Daten einfügen
  • Daten aktualisieren
  • Daten löschen
  • Gefundene Einträge zählen
  • DATE-Datenbankspalten
  • Datum- und Zeitfunktionen
  • MySQL Fehlermeldungen
  • Datenbankverbindung schließen
  • JOIN
  • Indizes
  • Normalformen
  • Fremdschlüssel
  • Übersicht SQL-Befehle
  • Crashkurs MySQL
  • Crashkurs MySQLi
  • Crashkurs PDO
Mit freundlicher Unterstützung von:
  • Punkt191 Werbeagentur

Hoster – Geringste Ausfallzeit

  1. netcup Ø 0 Min.
  2. webgo Ø 0 Min.
  3. Linevast Ø 3 Min.
  4. All-Inkl.com Ø 3 Min.
  5. checkdomain Ø 4 Min.
  6. dogado Ø 6 Min.
  7. Strato Ø 8 Min.
  8. manitu Ø 10 Min.
  9. 1&1 Ø 10 Min.
  10. DomainFactory Ø 14 Min.
» Mehr erfahren

Impressum | Datenschutz | Auf PHP-Einfach.de werben

© PHP-Einfach.de 2003 - 2025

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}