Zum Inhalt springen

Mysql/einführung: Unterschied zwischen den Versionen

Aus Foxwiki
 
(16 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].


Rechtliche Informationen finden Sie in den [https://dev.mysql.com/doc/mysql-getting-started/en/index.html#legalnotice Rechtlichen Hinweisen ].
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


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


== Verbinden mit dem MySQL-Server mit dem mysql-Client ==
=== Vorhandene Datenbanken anzeigen ===
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.
Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/show-databases.html SHOW DATABASES] Anweisung
* 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
<syntaxhighlight lang="sql" highlight="1" line>
* 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:
mysql> SHOW DATABASES;
C:\> mysql -u root -p
+--------------------+
| Database          |
+--------------------+
| information_schema |
| mysql             |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.00 sec)
</syntaxhighlight>


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:
=== Erstellen einer neuen Datenbank ===
* 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:
Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/create-database.html CREATE DATABASE] Anweisung
sudo grep 'temporary password' /var/log/mysqld.log
<syntaxhighlight lang="sql" highlight="1" line>
* 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].
mysql> CREATE DATABASE pets;
* 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.
Query OK, 1 row affected (0.01 sec)
* 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.
</syntaxhighlight>


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].
Prüfen Sie, ob die Datenbank erstellt worden ist
<syntaxhighlight lang="sql" highlight="1" line>
mysql> SHOW DATABASES;
+--------------------+
| Database          |
+--------------------+
| information_schema |
| mysql             |
| performance_schema |
| pets              |
| sys                |
+--------------------+
5 rows in set (0.00 sec)
</syntaxhighlight>


Sobald Sie mit dem MySQL-Server verbunden sind, wird eine Willkommensnachricht angezeigt und die Eingabeaufforderung <tt>mysql></tt> erscheint, die wie folgt aussieht:
=== 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
Database changed
</syntaxhighlight>


Welcome to the MySQL monitor. Commands end with ; or \g.
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
Your MySQL connection id is 4
* Als nächstes erstellen Sie eine Tabelle mit einer [https://dev.mysql.com/doc/refman/8.0/en/create-table.html CREATE TABLE] Anweisung
Server version: 5.7.32 MySQL Community Server (GPL)
<syntaxhighlight lang="sql" highlight="1" line>
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>
);
</syntaxhighlight>


Copyright (c) 2000, 2020, Oracle and/or its affiliates.
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


Oracle is a registered trademark of Oracle Corporation and/or its
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
affiliates. Other names may be trademarks of their respective
<syntaxhighlight lang="sql" highlight="1" line>
owners.
mysql> SHOW TABLES;
+----------------+
| Tables_in_pets |
+----------------+
| cats          |
+----------------+
1 row in set (0.00 sec)
</syntaxhighlight>


Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.


  mysql>
[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;
+-------+------------------+------+-----+---------+----------------+
| 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)
</syntaxhighlight>


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''';
=== 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
  ( 'Sandy', 'Lennon', '2015-01-03' ),
  ( 'Cookie', 'Casey', '2013-11-13' ),
  ( 'Charlie', 'River', '2016-05-21' );
</syntaxhighlight>


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.  
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


Hier sind ein paar nützliche Dinge, die Sie bei der Verwendung des '''mysql'''-Clients beachten sollten:
=== Abrufen von Datensätzen aus einer Tabelle ===
* 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.
Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/select.html SELECT]-Anweisung und "*", um alle Spalten abzugleichen
* 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.
<syntaxhighlight lang="sql" highlight="1" line>
* 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.
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)
</syntaxhighlight>


Um die Verbindung mit dem MySQL-Server zu trennen, geben Sie <tt>QUIT</tt> oder <tt>\q</tt> auf dem Client ein:
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';
+--------+
| name  |
+--------+
| Cookie |
+--------+
1 row in set (0.00 sec)
</syntaxhighlight>


mysql> QUIT
=== 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';
Query OK, 1 row affected (0.05 sec)


== Einige grundlegende Operationen mit MySQL ==
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)
</syntaxhighlight>


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.  
=== 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;
Query OK, 0 rows affected (0.24 sec)
Records: 0  Duplicates: 0  Warnings: 0
</syntaxhighlight>


Vorhandene Datenbanken anzeigen.&nbsp; Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/show-databases.html SHOW DATABASES] Anweisung:
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;
+--------+------------------+------+-----+---------+----------------+
| 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)
</syntaxhighlight>


mysql> SHOW DATABASES;
[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>
| Database          |
mysql> SHOW CREATE TABLE cats\G
+--------------------+
*************************** 1
| information_schema |
* row ***************************
| mysql              |
      Table: cats
| performance_schema |
Create Table: CREATE TABLE `cats` (
| sys                |
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+--------------------+
  `name` varchar(150) NOT NULL,
4 rows in set (0.00 sec)
  `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)
</syntaxhighlight>


Erstellen einer neuen Datenbank.&nbsp; Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/create-database.html CREATE DATABASE] Anweisung:  
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;
Query OK, 0 rows affected (0.19 sec)
Records: 0  Duplicates: 0  Warnings: 0


mysql> CREATE DATABASE pets;
mysql> DESCRIBE cats;
  Query OK, 1 row affected (0.01 sec)
+-------+------------------+------+-----+---------+----------------+
| 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)
</syntaxhighlight>


Prüfen Sie, ob die Datenbank erstellt worden ist:
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


mysql> SHOW DATABASES;
[[Kategorie:Mysql]]
+--------------------+
| Database          |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| pets              |
| sys                |
+--------------------+
5 rows in set (0.00 sec)
 
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:
 
mysql> USE pets
Database changed
 
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:
 
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 [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:
 
mysql> SHOW TABLES;
+----------------+
| Tables_in_pets |
+----------------+
| cats          |
+----------------+
1 row in set (0.00 sec)
 
[https://dev.mysql.com/doc/refman/8.0/en/explain.html 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.&nbsp; Verwenden Sie zum Beispiel eine [https://dev.mysql.com/doc/refman/8.0/en/insert.html 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 [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:
 
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 <tt>WHERE</tt>-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.&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:
 
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.&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:
 
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 [https://dev.mysql.com/doc/refman/8.0/en/explain.html 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)
 
[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:
 
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 [https://dev.mysql.com/doc/refman/8.0/en/alter-table.html 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 [https://dev.mysql.com/doc/refman/8.0/en/tutorial.html Tutorial] finden Sie weitere Anleitungen für die Arbeit mit dem MySQL-Server .

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