Zum Inhalt springen

Mysql/einführung: Unterschied zwischen den Versionen

Aus Foxwiki
Keine Bearbeitungszusammenfassung
 
(20 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
= Einführung in MySQL =
== Einführung ==
; MySQL ist die beliebteste Open-Source-Datenbank der Welt
* Trotz der leistungsstarken Funktionen von ist MySQL einfach einzurichten und leicht zu verwenden
* Im Folgenden finden Sie einige Anleitungen, die Ihnen helfen, MySQL in wenigen Schritten einzurichten und zum Laufen zu bringen
* Wir erklären auch, wie Sie einige grundlegende Operationen mit MySQL unter Verwendung des '''mysql''' Clients durchführen können


MySQL ist die beliebteste Open-Source-Datenbank der Welt. Trotz der leistungsstarken Funktionen von ist MySQL einfach einzurichten und leicht zu verwenden. Im Folgenden finden Sie einige Anleitungen, die Ihnen helfen, MySQL in wenigen Schritten einzurichten und zum Laufen zu bringen. Wir erklären auch, wie Sie einige grundlegende Operationen mit MySQL unter Verwendung des '''mysql''' Clients durchführen können.  
; Anmerkungen
* Die folgenden Anweisungen gelten nicht unbedingt für Versionen von MySQL, die älter als MySQL 5.7 sind
* Dies sind nur Anweisungen für eine Neuinstallation
* Wenn Sie bereits MySQL verwenden und auf eine neuere Version upgraden möchten, lesen Sie bitte [https://dev.mysql.com/doc/refman/8.0/en/upgrading.html MySQL upgraden]


Anmerkungen
; Rechtliche Informationen
* Die folgenden Anweisungen gelten nicht unbedingt für Versionen von MySQL, die älter als MySQL 5.7 sind.
* https://dev.mysql.com/doc/mysql-getting-started/en/index.html#legalnotice
* Dies sind nur Anweisungen für eine Neuinstallation. Wenn Sie bereits MySQL verwenden und auf eine neuere Version upgraden möchten, lesen Sie bitte [https://dev.mysql.com/doc/refman/8.0/en/upgrading.html MySQL upgraden].


Wenn Sie Hilfe bei der Verwendung von MySQL benötigen, besuchen Sie bitte die [http://forums.mysql.com/ MySQL-Foren], wo Sie unter Ihre Probleme mit anderen MySQL-Benutzern diskutieren können


== Grundlegende Operationen ==
Hier finden Sie einige grundlegende Operationen mit dem MySQL-Server
* [https://dev.mysql.com/doc/refman/8.0/en/sql-statements.html SQL-Anweisungen] erklärt detailliert die reichhaltige Syntax und die Funktionalität der SQL-Anweisungen, die unter dargestellt sind


Rechtliche Informationen finden Sie in den [https://dev.mysql.com/doc/mysql-getting-started/en/index.html#legalnotice Rechtlichen Hinweisen ].
=== Vorhandene Datenbanken anzeigen ===
 
Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/show-databases.html SHOW DATABASES] Anweisung
Wenn Sie Hilfe bei der Verwendung von MySQL benötigen, besuchen Sie bitte die [http://forums.mysql.com/ MySQL-Foren], wo Sie unter Ihre Probleme mit anderen MySQL-Benutzern diskutieren können.
<syntaxhighlight lang="sql" highlight="1" line>
 
 
== Installation und Start von MySQL ==
 
Es gibt verschiedene Möglichkeiten, MySQL zu installieren. Im Folgenden finden Sie unter die einfachsten Methoden für die Installation und den Start von MySQL auf verschiedenen Plattformen. * Linux.&nbsp; Der einfachste Weg, MySQL zu installieren, ist die Verwendung der [https://dev.mysql.com/downloads/repo/ MySQL repositories]:
** Für Yum-basierte Linux-Distributionen wie Oracle Linux, Red Hat Enterprise Linux und Fedora folgen Sie den Anweisungen in [https://dev.mysql.com/doc/mysql-yum-repo-quick-guide/en/ A Quick Guide to Using the MySQL Yum Repository]. Wenn Ihr System aus irgendeinem Grund das [https://dev.mysql.com/downloads/repo/yum/ MySQL Yum Repository] nicht verwenden kann, folgen Sie den Anweisungen in [https://dev.mysql.com/doc/refman/8.0/en/linux-installation-rpm.html MySQL unter Linux mit RPM-Paketen von Oracle installieren].
** Für APT-basierte Distributionen wie Debian und Ubuntu folgen Sie den Anweisungen in [https://dev.mysql.com/doc/mysql-apt-repo-quick-guide/en/ A Quick Guide to Using the MySQL APT Repository]. Wenn Ihr System aus irgendeinem Grund das [https://dev.mysql.com/downloads/repo/apt/ MySQL APT-Repository] nicht verwenden kann, folgen Sie den Anweisungen in [https://dev.mysql.com/doc/refman/8.0/en/linux-installation-debian.html MySQL unter Linux mit Debian-Paketen von Oracle installieren].
** Für SUSE Linux Enterprise befolgen Sie die Anweisungen in [https://dev.mysql.com/doc/mysql-sles-repo-quick-guide/en/ A Quick Guide to Using the MySQL SLES Repository]. Wenn Ihr System aus irgendeinem Grund das [https://dev.mysql.com/downloads/repo/suse/ MySQL SUSE Repository] nicht verwenden kann, folgen Sie den Anweisungen in [https://dev.mysql.com/doc/refman/8.0/en/linux-installation-rpm.html MySQL unter Linux mit RPM-Paketen von Oracle installieren].
 
Für Linux-Distributionen, die die [https://dev.mysql.com/downloads/repo/ MySQL Repositories] oder die oben genannten Installationspakete nicht unterstützen, können Sie MySQL mit generischen Binärdateien installieren:
** Laden Sie das <tt>.tar</tt> oder <tt>.tar.gz</tt> Archiv für die generischen Binärdateien für Linux von der [https://dev.mysql.com/downloads/mysql Download MySQL Community Server] Seite herunter.
** Siehe [https://dev.mysql.com/doc/refman/8.0/en/binary-installation.html MySQL unter Unix/Linux mit generischen Binärdateien installieren] für Anweisungen zur Installation der Binärdateien.
** Nachdem Sie die Binärdateien installiert haben, folgen Sie den Anweisungen unter [https://dev.mysql.com/doc/refman/8.0/en/data-directory-initialization.html Initialisierung des Datenverzeichnisses]. Es ist besonders wichtig, das zufällige <tt>Wurzelpasswort</tt> zu beachten, das während des Initialisierungsprozesses für Sie generiert wird; siehe [https://dev.mysql.com/doc/refman/8.0/en/data-directory-initialization.html Initialisierung des Datenverzeichnisses] für weitere Details.
** Befolgen Sie dann die Anweisungen unter [https://dev.mysql.com/doc/refman/8.0/en/starting-server.html Starten des Servers].
 
Detaillierte Anleitungen sowie weitere Methoden zur Installation finden Sie unter [https://dev.mysql.com/doc/refman/8.0/en/linux-installation.html MySQL auf Linux installieren].
* Microsoft Windows.&nbsp; Der empfohlene Weg, MySQL unter Microsoft Windows zu installieren, ist , den MySQL Installer zu verwenden; siehe [https://dev.mysql.com/doc/refman/5.7/en/windows-installation.html#windows-installation-simple MySQL Installer Methode], wie Sie den MySQL Installer herunterladen und ausführen. Eine ausführliche Erklärung für jeden Schritt des Installationsassistenten finden Sie unter [https://dev.mysql.com/doc/refman/8.0/en/mysql-installer.html MySQL Installer for Windows]. <br/>Wenn Sie sich während des Installationsprozesses dafür entschieden haben, MySQL als Windows-Dienst zu konfigurieren, was die Standardoption ist (siehe [https://dev.mysql.com/doc/refman/8.0/en/mysql-installer-workflow.html#server-windows-service Windows-Dienst] für Details), wird der MySQL-Server automatisch gestartet, nachdem der Installationsprozess abgeschlossen ist. <br/>Detaillierte Informationen zur Windows-Installation, einschließlich alternativer Installationsmethoden und Anweisungen zur Fehlerbehebung, finden Sie in [https://dev.mysql.com/doc/refman/8.0/en/windows-installation.html MySQL unter Microsoft Windows installieren].
* macOS.&nbsp; Der empfohlene Weg für die Installation von MySQL auf macOS ist die Verwendung von dem macOS-Installationspaket. Siehe [https://dev.mysql.com/doc/refman/8.0/en/macos-installation-pkg.html MySQL auf macOS mit nativen Paketen installieren] zum Herunterladen von und Ausführen des Installationspakets sowie zum anschließenden Starten des MySQL-Servers . <br/>Detaillierte Informationen zur Installation unter macOS finden Sie unter in [https://dev.mysql.com/doc/refman/8.0/en/macos-installation.html MySQL unter macOS installieren].
* Andere Plattformen.&nbsp; Für Installationen auf anderen Plattformen (z.B. FreeBSD und Solaris) sowie für Installationsmethoden, die nicht unter beschrieben sind, siehe [https://dev.mysql.com/doc/refman/8.0/en/installing.html MySQL installieren].
 
 
 
== Verbinden mit dem MySQL-Server mit dem mysql-Client ==
 
Sobald Ihr MySQL-Server läuft, können Sie sich als mit dem Superuser <tt>root</tt> mit dem [https://dev.mysql.com/doc/refman/8.0/en/mysql.html mysql] Client verbinden. * Unter Linux geben Sie den folgenden Befehl in der Kommandozeile Terminal ein (für die Installation mit generischen Binärdateien müssen Sie möglicherweise zuerst in den Ordner <tt>bin</tt> unter dem Basisverzeichnis Ihrer MySQL-Installation wechseln): <br/>$> mysql -u root -p
* Unter Windows klicken Sie auf Start, Alle Programme, MySQL, MySQL 5.7 Command Line Client (bzw. MySQL 8.0 Command Line Client). Wenn Sie MySQL nicht mit dem MySQL Installer installiert haben, öffnen Sie eine Eingabeaufforderung, gehen Sie in den Ordner <tt>bin</tt> unter dem Basisverzeichnis Ihrer MySQL-Installation und geben Sie den folgenden Befehl ein: <br/>C:\> mysql -u root -p
 
 
 
Sie werden dann nach dem <tt>root</tt>-Passwort gefragt, das je nach der Art und Weise, wie Sie MySQL installiert haben, auf unterschiedliche Weise vergeben wurde. In den oben genannten Installations- und Initialisierungsanweisungen wird das <tt>root</tt>-Passwort bereits erklärt, aber hier ist eine kurze Zusammenfassung: * Bei Installationen, die das MySQL Yum-Repository, das MySQL SUSE -Repository oder direkt von Oracle heruntergeladene RPM-Pakete verwenden, finden Sie unter das generierte <tt>root</tt>-Passwort im Fehlerprotokoll . Zeigen Sie es z. B. mit dem folgenden Befehl an: <br/>$> sudo grep 'temporary password' /var/log/mysqld.log
* Für Installationen, die das MySQL APT Repository oder Debian Pakete verwenden, die direkt von Oracle heruntergeladen wurden, sollten Sie das <tt>root</tt> Passwort bereits selbst vergeben haben; wenn Sie das aus irgendeinem Grund nicht getan haben, lesen Sie die "Wichtige" Notiz [https://dev.mysql.com/doc/refman/8.0/en/linux-installation-debian.html#linux-installing-debian-password hier] oder [https://dev.mysql.com/doc/refman/8.0/en/resetting-permissions.html Wie man das Root Passwort zurücksetzt].
* Bei Installationen unter Linux mit den generischen Binärdateien, gefolgt von einer Initialisierung des Datenverzeichnisses mit <tt>mysqld --initialize</tt>, wie in [https://dev.mysql.com/doc/refman/8.0/en/data-directory-initialization.html Initialisierung des Datenverzeichnisses] beschrieben, wird das generierte <tt>root</tt>-Passwort im Standard-Fehlerstrom während der Initialisierung des Datenverzeichnisses angezeigt: <br/>[Warning] A temporary password is generated for root@localhost:<br/>iTag*AfrH5ej<br/>Hinweis <br/>Abhängig von der Konfiguration, die Sie zur Initialisierung des MySQL-Servers verwendet haben, könnte die Fehlerausgabe an das [https://dev.mysql.com/doc/refman/8.0/en/error-log.html MySQL-Fehlerprotokoll] geleitet worden sein; gehen Sie dorthin und überprüfen Sie das Passwort, wenn Sie die obige Meldung nicht auf Ihrem Bildschirm sehen. Das Fehlerprotokoll ist eine Datei mit einer <tt>.err</tt>-Erweiterung, die normalerweise unter im Datenverzeichnis des Servers zu finden ist (der Speicherort hängt von der Konfiguration des Servers ab, ist aber wahrscheinlich der <tt>data</tt>-Ordner unter dem Basisverzeichnis Ihrer MySQL-Installation, oder der <tt>/var/lib/mysql</tt>-Ordner). <br/>Wenn Sie stattdessen das Datenverzeichnis mit <tt>mysqld --initialize-insecure</tt> initialisiert haben, ist das <tt>root</tt> Passwort leer.
* Für Installationen unter Windows mit dem MySQL Installer und OS X mit dem Installer-Paket sollten Sie selbst ein <tt>root</tt>-Passwort vergeben haben.
 
 
 
Wenn Sie das <tt>Wurzelpasswort</tt> vergessen haben, das Sie gewählt haben, oder Probleme haben, das temporäre <tt>Wurzelpasswort</tt> zu finden, das für Sie generiert wurde, lesen Sie [https://dev.mysql.com/doc/refman/8.0/en/resetting-permissions.html Wie man das Wurzelpasswort zurücksetzt].
 
Sobald Sie mit dem MySQL-Server verbunden sind, wird eine Willkommensnachricht angezeigt und die Eingabeaufforderung <tt>mysql></tt> erscheint, die wie folgt aussieht:
 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.7.32 MySQL Community Server (GPL)
 
Copyright (c) 2000, 2020, Oracle and/or its affiliates.
 
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
 
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
 
mysql>
 
Wenn Sie sich zu diesem Zeitpunkt mit einem temporären <tt>root</tt>-Passwort angemeldet haben, das während der Installation oder des Initialisierungsprozesses generiert wurde (was der Fall ist, wenn Sie MySQL mit dem MySQL Yum-Repository oder mit RPM Paketen oder generischen Binärdateien von Oracle installiert haben), ändern Sie Ihr <tt>root</tt>-Passwort, indem Sie die folgende Anweisung an der Eingabeaufforderung eingeben:
 
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '''new_password''';
 
Solange Sie Ihr <tt>root</tt>-Passwort nicht ändern, können Sie keine Superuser-Rechte ausüben, auch wenn Sie als <tt>root</tt> angemeldet sind.
 
Hier sind ein paar nützliche Dinge, die Sie bei der Verwendung des '''mysql'''-Clients beachten sollten: * Client-Befehle (z. B. <tt>help</tt>, <tt>quit</tt> und <tt>clear</tt>) und Schlüsselwörter in SQL-Anweisungen (z. B. [https://dev.mysql.com/doc/refman/8.0/en/select.html SELECT], [https://dev.mysql.com/doc/refman/8.0/en/create-table.html CREATE TABLE] und [https://dev.mysql.com/doc/refman/8.0/en/insert.html INSERT]) unterscheiden nicht zwischen Groß- und Kleinschreibung.
* Bei Spaltennamen wird zwischen Groß- und Kleinschreibung unterschieden. Bei Tabellennamen wird auf den meisten Unix-ähnlichen Plattformen die Groß- und Kleinschreibung beachtet ( ), auf Windows-Plattformen jedoch nicht ( ). Die Unterscheidung zwischen Groß- und Kleinschreibung während des Zeichenfolgenvergleichs hängt von der von Ihnen verwendeten Zeichenkollation ab. Im Allgemeinen ist es eine gute Idee, alle Bezeichner (Datenbanknamen, Tabellennamen, Spaltennamen usw.) und Zeichenketten unter Berücksichtigung der Groß- und Kleinschreibung zu behandeln. Siehe [https://dev.mysql.com/doc/refman/8.0/en/identifier-case-sensitivity.html Unterscheidung zwischen Groß- und Kleinschreibung bei Bezeichnern] und [https://dev.mysql.com/doc/refman/8.0/en/case-sensitivity.html Unterscheidung zwischen Groß- und Kleinschreibung bei Stringsuchen] für weitere Details.
* Sie können Ihre SQL-Anweisungen in mehreren Zeilen eingeben, indem Sie <tt>Enter</tt> in der Mitte drücken. Die Eingabe eines Semikolons (<tt><nowiki>;</nowiki></tt>) gefolgt von einem <tt>Enter</tt> beendet eine SQL-Anweisung und sendet sie zur Ausführung an den Server; dasselbe geschieht, wenn eine Anweisung mit <tt>\g</tt> oder <tt>\G</tt> beendet wird (bei letzterem werden die zurückgegebenen Ergebnisse vertikal angezeigt). Für Client-Befehle (z. B. <tt>Hilfe</tt>, <tt>Beenden</tt> und <tt>Löschen</tt>) ist jedoch kein Abschlusszeichen erforderlich.
 
 
 
Um die Verbindung mit dem MySQL-Server zu trennen, geben Sie <tt>QUIT</tt> oder <tt>\q</tt> auf dem Client ein:
 
mysql> QUIT
 
== Einige grundlegende Operationen mit MySQL ==
 
Hier finden Sie einige grundlegende Operationen mit dem MySQL-Server. [https://dev.mysql.com/doc/refman/8.0/en/sql-statements.html SQL-Anweisungen] erklärt detailliert die reichhaltige Syntax und die Funktionalität der SQL-Anweisungen, die unter dargestellt sind.
 
Vorhandene Datenbanken anzeigen.&nbsp; Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/show-databases.html SHOW DATABASES] Anweisung:
 
mysql> SHOW DATABASES;
mysql> SHOW DATABASES;
+--------------------+
+--------------------+
Zeile 98: Zeile 32:
+--------------------+
+--------------------+
4 rows in set (0.00 sec)
4 rows in set (0.00 sec)
</syntaxhighlight>


Erstellen einer neuen Datenbank.&nbsp; Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/create-database.html CREATE DATABASE] Anweisung:
=== Erstellen einer neuen Datenbank ===
 
Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/create-database.html CREATE DATABASE] Anweisung
<syntaxhighlight lang="sql" highlight="1" line>
mysql> CREATE DATABASE pets;
mysql> CREATE DATABASE pets;
Query OK, 1 row affected (0.01 sec)
Query OK, 1 row affected (0.01 sec)
</syntaxhighlight>


Prüfen Sie, ob die Datenbank erstellt worden ist:
Prüfen Sie, ob die Datenbank erstellt worden ist
 
<syntaxhighlight lang="sql" highlight="1" line>
mysql> SHOW DATABASES;
mysql> SHOW DATABASES;
+--------------------+
+--------------------+
Zeile 117: Zeile 54:
+--------------------+
+--------------------+
5 rows in set (0.00 sec)
5 rows in set (0.00 sec)
</syntaxhighlight>


Erstellen einer Tabelle innerhalb einer Datenbank.&nbsp; Wählen Sie zunächst die Datenbank aus, in der Sie die Tabelle mit einer [https://dev.mysql.com/doc/refman/8.0/en/use.html USE]-Anweisung erstellen möchten:
=== Erstellen einer Tabelle innerhalb einer Datenbank ===
 
Wählen Sie zunächst die Datenbank aus, in der Sie die Tabelle mit einer [https://dev.mysql.com/doc/refman/8.0/en/use.html USE]-Anweisung erstellen möchten
<syntaxhighlight lang="sql" highlight="1" line>
mysql> USE pets
mysql> USE pets
Database changed
Database changed
</syntaxhighlight>


Die Anweisung [https://dev.mysql.com/doc/refman/8.0/en/use.html USE] weist MySQL an, <tt>pets</tt> als Standarddatenbank für nachfolgende Anweisungen zu verwenden. Als nächstes erstellen Sie eine Tabelle mit einer [https://dev.mysql.com/doc/refman/8.0/en/create-table.html CREATE TABLE] Anweisung:
Die Anweisung [https://dev.mysql.com/doc/refman/8.0/en/use.html USE] weist MySQL an, <tt>pets</tt> als Standarddatenbank für nachfolgende Anweisungen zu verwenden
 
* Als nächstes erstellen Sie eine Tabelle mit einer [https://dev.mysql.com/doc/refman/8.0/en/create-table.html CREATE TABLE] Anweisung
<syntaxhighlight lang="sql" highlight="1" line>
CREATE TABLE cats
CREATE TABLE cats
(
(
Zeile 133: Zeile 74:
   PRIMARY KEY    (id)                                  <nowiki># Make the id the primary key</nowiki>
   PRIMARY KEY    (id)                                  <nowiki># Make the id the primary key</nowiki>
);
);
</syntaxhighlight>


Datentypen, die Sie in jeder Spalte verwenden können, werden in [https://dev.mysql.com/doc/refman/8.0/en/data-types.html Datentypen] erläutert. [https://dev.mysql.com/doc/refman/8.0/en/primary-key-optimization.html Primärschlüssel-Optimierung] erklärt das Konzept von eines Primärschlüssels. Was auf ein <tt><nowiki>#</nowiki></tt> in jeder Zeile folgt, ist ein Kommentar, der vom '''mysql''' Client ignoriert wird; siehe [https://dev.mysql.com/doc/refman/8.0/en/comments.html Kommentare] für andere Kommentararten.
Datentypen, die Sie in jeder Spalte verwenden können, werden in [https://dev.mysql.com/doc/refman/8.0/en/data-types.html Datentypen] erläutert. [https://dev.mysql.com/doc/refman/8.0/en/primary-key-optimization.html Primärschlüssel-Optimierung] erklärt das Konzept von eines Primärschlüssels
 
* Was auf ein <tt><nowiki>#</nowiki></tt> in jeder Zeile folgt, ist ein Kommentar, der vom '''mysql''' Client ignoriert wird; siehe [https://dev.mysql.com/doc/refman/8.0/en/comments.html Kommentare] für andere Kommentararten
Prüfen Sie, ob die Tabelle mit einer [https://dev.mysql.com/doc/refman/8.0/en/show-tables.html SHOW TABLES] Anweisung erstellt wurde:


Prüfen Sie, ob die Tabelle mit einer [https://dev.mysql.com/doc/refman/8.0/en/show-tables.html SHOW TABLES] Anweisung erstellt wurde
<syntaxhighlight lang="sql" highlight="1" line>
mysql> SHOW TABLES;
mysql> SHOW TABLES;
+----------------+
+----------------+
Zeile 145: Zeile 88:
+----------------+
+----------------+
1 row in set (0.00 sec)
1 row in set (0.00 sec)
</syntaxhighlight>


[https://dev.mysql.com/doc/refman/8.0/en/explain.html DESCRIBE] zeigt Informationen über alle Spalten einer Tabelle:


[https://dev.mysql.com/doc/refman/8.0/en/explain.html DESCRIBE] zeigt Informationen über alle Spalten einer Tabelle
<syntaxhighlight lang="sql" highlight="1" line>
mysql> DESCRIBE cats;
mysql> DESCRIBE cats;
+-------+------------------+------+-----+---------+----------------+
+-------+------------------+------+-----+---------+----------------+
Zeile 158: Zeile 103:
+-------+------------------+------+-----+---------+----------------+
+-------+------------------+------+-----+---------+----------------+
4 rows in set (0.00 sec)
4 rows in set (0.00 sec)
</syntaxhighlight>


Hinzufügen von Datensätzen in eine Tabelle.&nbsp; Verwenden Sie zum Beispiel eine [https://dev.mysql.com/doc/refman/8.0/en/insert.html INSERT...VALUES]-Anweisung:


=== Hinzufügen von Datensätzen in eine Tabelle ===
Verwenden Sie zum Beispiel eine [https://dev.mysql.com/doc/refman/8.0/en/insert.html INSERT...VALUES]-Anweisung
<syntaxhighlight lang="sql" highlight="1" line>
INSERT INTO cats ( name, owner, birth) VALUES
INSERT INTO cats ( name, owner, birth) VALUES
   ( 'Sandy', 'Lennon', '2015-01-03' ),
   ( 'Sandy', 'Lennon', '2015-01-03' ),
   ( 'Cookie', 'Casey', '2013-11-13' ),
   ( 'Cookie', 'Casey', '2013-11-13' ),
   ( 'Charlie', 'River', '2016-05-21' );
   ( 'Charlie', 'River', '2016-05-21' );
</syntaxhighlight>


Siehe [https://dev.mysql.com/doc/refman/8.0/en/literals.html Literale Werte] für das Schreiben von Strings, Datumswerten und anderen Arten von Literalen in MySQL.
Siehe [https://dev.mysql.com/doc/refman/8.0/en/literals.html Literale Werte] für das Schreiben von Strings, Datumswerten und anderen Arten von Literalen in MySQL
 
Abrufen von Datensätzen aus einer Tabelle.&nbsp; Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/select.html SELECT]-Anweisung und "*", um alle Spalten abzugleichen:


=== Abrufen von Datensätzen aus einer Tabelle ===
Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/select.html SELECT]-Anweisung und "*", um alle Spalten abzugleichen
<syntaxhighlight lang="sql" highlight="1" line>
mysql> SELECT * FROM cats;
mysql> SELECT * FROM cats;
+----+---------+--------+------------+
+----+---------+--------+------------+
Zeile 179: Zeile 129:
+----+---------+--------+------------+
+----+---------+--------+------------+
3 rows in set (0.00 sec)
3 rows in set (0.00 sec)
</syntaxhighlight>


Um bestimmte Spalten und Zeilen nach einer bestimmten Bedingung auszuwählen, verwenden Sie die <tt>WHERE</tt>-Klausel:
Um bestimmte Spalten und Zeilen nach einer bestimmten Bedingung auszuwählen, verwenden Sie die <tt>WHERE</tt>-Klausel
 
<syntaxhighlight lang="sql" highlight="1" line>
mysql> SELECT name FROM cats WHERE owner = 'Casey';
mysql> SELECT name FROM cats WHERE owner = 'Casey';
+--------+
+--------+
Zeile 189: Zeile 140:
+--------+
+--------+
1 row in set (0.00 sec)
1 row in set (0.00 sec)
</syntaxhighlight>


Löschen eines Datensatzes aus einer Tabelle.&nbsp; Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/delete.html DELETE]-Anweisung, um einen -Datensatz aus einer Tabelle zu löschen, und geben Sie das Kriterium für das Löschen mit der <tt>WHERE</tt>-Klausel an:
=== Löschen eines Datensatzes aus einer Tabelle ===
 
Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/delete.html DELETE]-Anweisung, um einen -Datensatz aus einer Tabelle zu löschen, und geben Sie das Kriterium für das Löschen mit der <tt>WHERE</tt>-Klausel an
<syntaxhighlight lang="sql" highlight="1" line>
mysql> DELETE FROM cats WHERE name='Cookie';
mysql> DELETE FROM cats WHERE name='Cookie';
Query OK, 1 row affected (0.05 sec)
Query OK, 1 row affected (0.05 sec)
Zeile 203: Zeile 156:
+----+---------+--------+------------+
+----+---------+--------+------------+
2 rows in set (0.00 sec)
2 rows in set (0.00 sec)
</syntaxhighlight>


Hinzufügen oder Löschen einer Spalte aus einer Tabelle.&nbsp; Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/alter-table.html ALTER TABLE...ADD] Anweisung, um eine Spalte hinzuzufügen. Sie können z.B. eine <tt>AFTER</tt> Klausel verwenden, um den Ort der neuen Spalte anzugeben:
=== Hinzufügen oder Löschen einer Spalte aus einer Tabelle ===
 
Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/alter-table.html ALTER TABLE...ADD] Anweisung, um eine Spalte hinzuzufügen
* Sie können z.B
* eine <tt>AFTER</tt> Klausel verwenden, um den Ort der neuen Spalte anzugeben
<syntaxhighlight lang="sql" highlight="1" line>
mysql> ALTER TABLE cats ADD gender CHAR(1) AFTER name;
mysql> ALTER TABLE cats ADD gender CHAR(1) AFTER name;
Query OK, 0 rows affected (0.24 sec)
Query OK, 0 rows affected (0.24 sec)
Records: 0  Duplicates: 0  Warnings: 0
Records: 0  Duplicates: 0  Warnings: 0
</syntaxhighlight>


Verwenden Sie [https://dev.mysql.com/doc/refman/8.0/en/explain.html DESCRIBE], um das Ergebnis zu überprüfen:
Verwenden Sie [https://dev.mysql.com/doc/refman/8.0/en/explain.html DESCRIBE], um das Ergebnis zu überprüfen
 
<syntaxhighlight lang="sql" highlight="1" line>
mysql> DESCRIBE cats;
mysql> DESCRIBE cats;
+--------+------------------+------+-----+---------+----------------+
+--------+------------------+------+-----+---------+----------------+
Zeile 223: Zeile 181:
+--------+------------------+------+-----+---------+----------------+
+--------+------------------+------+-----+---------+----------------+
5 rows in set (0.00 sec)
5 rows in set (0.00 sec)
</syntaxhighlight>


[https://dev.mysql.com/doc/refman/8.0/en/show-create-table.html SHOW CREATE TABLE] zeigt eine [https://dev.mysql.com/doc/refman/8.0/en/create-table.html CREATE TABLE] Anweisung, die noch mehr Details über die Tabelle liefert:
[https://dev.mysql.com/doc/refman/8.0/en/show-create-table.html SHOW CREATE TABLE] zeigt eine [https://dev.mysql.com/doc/refman/8.0/en/create-table.html CREATE TABLE] Anweisung, die noch mehr Details über die Tabelle liefert
 
<syntaxhighlight lang="sql" highlight="1" line>
mysql> SHOW CREATE TABLE cats\G
mysql> SHOW CREATE TABLE cats\G
<nowiki>*************************** 1. row ***************************</nowiki>
*************************** 1
* row ***************************
       Table: cats
       Table: cats
Create Table: CREATE TABLE `cats` (
Create Table: CREATE TABLE `cats` (
Zeile 238: Zeile 198:
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1
1 row in set (0.00 sec)
1 row in set (0.00 sec)
</syntaxhighlight>


Verwenden Sie [https://dev.mysql.com/doc/refman/8.0/en/alter-table.html ALTER TABLE...DROP] um eine Spalte zu löschen:
Verwenden Sie [https://dev.mysql.com/doc/refman/8.0/en/alter-table.html ALTER TABLE...DROP] um eine Spalte zu löschen
 
<syntaxhighlight lang="sql" highlight="1" line>
mysql> ALTER TABLE cats DROP gender;
mysql> ALTER TABLE cats DROP gender;
Query OK, 0 rows affected (0.19 sec)
Query OK, 0 rows affected (0.19 sec)
Zeile 255: Zeile 216:
+-------+------------------+------+-----+---------+----------------+
+-------+------------------+------+-----+---------+----------------+
4 rows in set (0.00 sec)
4 rows in set (0.00 sec)
</syntaxhighlight>
Im [https://dev.mysql.com/doc/refman/8.0/en/tutorial.html Tutorial] finden Sie weitere Anleitungen für die Arbeit mit dem MySQL-Server


Im [https://dev.mysql.com/doc/refman/8.0/en/tutorial.html Tutorial] finden Sie weitere Anleitungen für die Arbeit mit dem MySQL-Server .
[[Kategorie:Mysql]]

Aktuelle Version vom 20. Dezember 2025, 20:45 Uhr

Einführung

MySQL ist die beliebteste Open-Source-Datenbank der Welt
  • Trotz der leistungsstarken Funktionen von ist MySQL einfach einzurichten und leicht zu verwenden
  • Im Folgenden finden Sie einige Anleitungen, die Ihnen helfen, MySQL in wenigen Schritten einzurichten und zum Laufen zu bringen
  • Wir erklären auch, wie Sie einige grundlegende Operationen mit MySQL unter Verwendung des mysql Clients durchführen können
Anmerkungen
  • Die folgenden Anweisungen gelten nicht unbedingt für Versionen von MySQL, die älter als MySQL 5.7 sind
  • Dies sind nur Anweisungen für eine Neuinstallation
  • Wenn Sie bereits MySQL verwenden und auf eine neuere Version upgraden möchten, lesen Sie bitte MySQL upgraden
Rechtliche Informationen

Wenn Sie Hilfe bei der Verwendung von MySQL benötigen, besuchen Sie bitte die MySQL-Foren, wo Sie unter Ihre Probleme mit anderen MySQL-Benutzern diskutieren können

Grundlegende Operationen

Hier finden Sie einige grundlegende Operationen mit dem MySQL-Server

  • SQL-Anweisungen erklärt detailliert die reichhaltige Syntax und die Funktionalität der SQL-Anweisungen, die unter dargestellt sind

Vorhandene Datenbanken anzeigen

Verwenden Sie eine SHOW DATABASES Anweisung

mysql> SHOW DATABASES;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.00 sec)

Erstellen einer neuen Datenbank

Verwenden Sie eine CREATE DATABASE Anweisung

mysql> CREATE DATABASE pets;
Query OK, 1 row affected (0.01 sec)

Prüfen Sie, ob die Datenbank erstellt worden ist

mysql> SHOW DATABASES;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| pets               |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

Erstellen einer Tabelle innerhalb einer Datenbank

Wählen Sie zunächst die Datenbank aus, in der Sie die Tabelle mit einer USE-Anweisung erstellen möchten

mysql> USE pets
Database changed

Die Anweisung USE weist MySQL an, pets als Standarddatenbank für nachfolgende Anweisungen zu verwenden

  • Als nächstes erstellen Sie eine Tabelle mit einer CREATE TABLE Anweisung
CREATE TABLE cats
(
  id              INT unsigned NOT NULL AUTO_INCREMENT, # Unique ID for the record
  name            VARCHAR(150) NOT NULL,                <nowiki># Name of the cat</nowiki>
  owner           VARCHAR(150) NOT NULL,                <nowiki># Owner of the cat</nowiki>
  birth           DATE NOT NULL,                        <nowiki># Birthday of the cat</nowiki>
  PRIMARY KEY     (id)                                  <nowiki># Make the id the primary key</nowiki>
);

Datentypen, die Sie in jeder Spalte verwenden können, werden in Datentypen erläutert. Primärschlüssel-Optimierung erklärt das Konzept von eines Primärschlüssels

  • Was auf ein # in jeder Zeile folgt, ist ein Kommentar, der vom mysql Client ignoriert wird; siehe Kommentare für andere Kommentararten

Prüfen Sie, ob die Tabelle mit einer SHOW TABLES Anweisung erstellt wurde

mysql> SHOW TABLES;
+----------------+
| Tables_in_pets |
+----------------+
| cats           |
+----------------+
1 row in set (0.00 sec)


DESCRIBE zeigt Informationen über alle Spalten einer Tabelle

mysql> DESCRIBE cats;
+-------+------------------+------+-----+---------+----------------+
| Field | Type             | Null | Key | Default | Extra          |
+-------+------------------+------+-----+---------+----------------+
| id    | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(150)     | NO   |     | NULL    |                |
| owner | varchar(150)     | NO   |     | NULL    |                |
| birth | date             | NO   |     | NULL    |                |
+-------+------------------+------+-----+---------+----------------+
4 rows in set (0.00 sec)


Hinzufügen von Datensätzen in eine Tabelle

Verwenden Sie zum Beispiel eine INSERT...VALUES-Anweisung

INSERT INTO cats ( name, owner, birth) VALUES
  ( 'Sandy', 'Lennon', '2015-01-03' ),
  ( 'Cookie', 'Casey', '2013-11-13' ),
  ( 'Charlie', 'River', '2016-05-21' );

Siehe Literale Werte für das Schreiben von Strings, Datumswerten und anderen Arten von Literalen in MySQL

Abrufen von Datensätzen aus einer Tabelle

Verwenden Sie eine SELECT-Anweisung und "*", um alle Spalten abzugleichen

mysql> SELECT * FROM cats;
+----+---------+--------+------------+
| id | name    | owner  | birth      |
+----+---------+--------+------------+
|  1 | Sandy   | Lennon | 2015-01-03 |
|  2 | Cookie  | Casey  | 2013-11-13 |
|  3 | Charlie | River  | 2016-05-21 |
+----+---------+--------+------------+
3 rows in set (0.00 sec)

Um bestimmte Spalten und Zeilen nach einer bestimmten Bedingung auszuwählen, verwenden Sie die WHERE-Klausel

mysql> SELECT name FROM cats WHERE owner = 'Casey';
+--------+
| name   |
+--------+
| Cookie |
+--------+
1 row in set (0.00 sec)

Löschen eines Datensatzes aus einer Tabelle

Verwenden Sie eine DELETE-Anweisung, um einen -Datensatz aus einer Tabelle zu löschen, und geben Sie das Kriterium für das Löschen mit der WHERE-Klausel an

mysql> DELETE FROM cats WHERE name='Cookie';
Query OK, 1 row affected (0.05 sec)

mysql> SELECT * FROM cats;
+----+---------+--------+------------+
| id | name    | owner  | birth      |
+----+---------+--------+------------+
|  1 | Sandy   | Lennon | 2015-01-03 |
|  3 | Charlie | River  | 2016-05-21 |
+----+---------+--------+------------+
2 rows in set (0.00 sec)

Hinzufügen oder Löschen einer Spalte aus einer Tabelle

Verwenden Sie eine ALTER TABLE...ADD Anweisung, um eine Spalte hinzuzufügen

  • Sie können z.B
  • eine AFTER Klausel verwenden, um den Ort der neuen Spalte anzugeben
mysql> ALTER TABLE cats ADD gender CHAR(1) AFTER name;
Query OK, 0 rows affected (0.24 sec)
Records: 0  Duplicates: 0  Warnings: 0

Verwenden Sie DESCRIBE, um das Ergebnis zu überprüfen

mysql> DESCRIBE cats;
+--------+------------------+------+-----+---------+----------------+
| Field  | Type             | Null | Key | Default | Extra          |
+--------+------------------+------+-----+---------+----------------+
| id     | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name   | varchar(150)     | NO   |     | NULL    |                |
| gender | char(1)          | YES  |     | NULL    |                |
| owner  | varchar(150)     | NO   |     | NULL    |                |
| birth  | date             | NO   |     | NULL    |                |
+--------+------------------+------+-----+---------+----------------+
5 rows in set (0.00 sec)

SHOW CREATE TABLE zeigt eine CREATE TABLE Anweisung, die noch mehr Details über die Tabelle liefert

mysql> SHOW CREATE TABLE cats\G
*************************** 1
* row ***************************
       Table: cats
Create Table: CREATE TABLE `cats` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(150) NOT NULL,
  `gender` char(1) DEFAULT NULL,
  `owner` varchar(150) NOT NULL,
  `birth` date NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1
1 row in set (0.00 sec)

Verwenden Sie ALTER TABLE...DROP um eine Spalte zu löschen

mysql> ALTER TABLE cats DROP gender;
Query OK, 0 rows affected (0.19 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> DESCRIBE cats;
+-------+------------------+------+-----+---------+----------------+
| Field | Type             | Null | Key | Default | Extra          |
+-------+------------------+------+-----+---------+----------------+
| id    | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(150)     | NO   |     | NULL    |                |
| owner | varchar(150)     | NO   |     | NULL    |                |
| birth | date             | NO   |     | NULL    |                |
+-------+------------------+------+-----+---------+----------------+
4 rows in set (0.00 sec)

Im Tutorial finden Sie weitere Anleitungen für die Arbeit mit dem MySQL-Server