|
|
| (18 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 |
|
| |
|
| == Installation und Start von MySQL == | | === Vorhandene Datenbanken anzeigen === |
| | Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/show-databases.html SHOW DATABASES] Anweisung |
| | <syntaxhighlight lang="sql" highlight="1" line> |
| | mysql> SHOW DATABASES; |
| | +--------------------+ |
| | | Database | |
| | +--------------------+ |
| | | information_schema | |
| | | mysql | |
| | | performance_schema | |
| | | sys | |
| | +--------------------+ |
| | 4 rows in set (0.00 sec) |
| | </syntaxhighlight> |
|
| |
|
| 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. Der einfachste Weg, MySQL zu installieren, ist die Verwendung der [https://dev.mysql.com/downloads/repo/ MySQL repositories]:
| | === Erstellen einer neuen Datenbank === |
| ** 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].
| | Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/create-database.html CREATE DATABASE] Anweisung |
| ** 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].
| | <syntaxhighlight lang="sql" highlight="1" line> |
| ** 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].
| | mysql> CREATE DATABASE pets; |
| | Query OK, 1 row affected (0.01 sec) |
| | </syntaxhighlight> |
|
| |
|
| 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:
| | Prüfen Sie, ob die Datenbank erstellt worden ist |
| ** 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.
| | <syntaxhighlight lang="sql" highlight="1" line> |
| ** 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.
| | mysql> SHOW DATABASES; |
| ** 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].
| | | Database | |
| | +--------------------+ |
| | | information_schema | |
| | | mysql | |
| | | performance_schema | |
| | | pets | |
| | | sys | |
| | +--------------------+ |
| | 5 rows in set (0.00 sec) |
| | </syntaxhighlight> |
|
| |
|
| 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].
| | === Erstellen einer Tabelle innerhalb einer Datenbank === |
| * Microsoft Windows. 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].
| | 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 |
| * macOS. 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].
| | <syntaxhighlight lang="sql" highlight="1" line> |
| * Andere Plattformen. 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].
| | mysql> USE pets |
| | Database changed |
| | </syntaxhighlight> |
|
| |
|
| == Verbinden mit dem MySQL-Server mit dem mysql-Client ==
| | 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 |
| 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.
| | * Als nächstes erstellen Sie eine Tabelle mit einer [https://dev.mysql.com/doc/refman/8.0/en/create-table.html CREATE TABLE] 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: <br/>C:\> mysql -u root -p
| | 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> |
|
| |
|
| 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:
| | 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 |
| * 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
| | * 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 |
| * 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].
| | 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; |
| | +----------------+ |
| | | Tables_in_pets | |
| | +----------------+ |
| | | cats | |
| | +----------------+ |
| | 1 row 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:
| |
|
| |
|
| Welcome to the MySQL monitor. Commands end with ; or \g.
| | [https://dev.mysql.com/doc/refman/8.0/en/explain.html DESCRIBE] zeigt Informationen über alle Spalten einer Tabelle |
| Your MySQL connection id is 4
| | <syntaxhighlight lang="sql" highlight="1" line> |
| Server version: 5.7.32 MySQL Community Server (GPL) | | 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> |
|
| |
|
| Copyright (c) 2000, 2020, Oracle and/or its affiliates.
| |
|
| |
|
| Oracle is a registered trademark of Oracle Corporation and/or its
| | === Hinzufügen von Datensätzen in eine Tabelle === |
| affiliates. Other names may be trademarks of their respective
| | Verwenden Sie zum Beispiel eine [https://dev.mysql.com/doc/refman/8.0/en/insert.html INSERT...VALUES]-Anweisung |
| owners.
| | <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> |
|
| |
|
| Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
| | 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 |
|
| |
|
| mysql> | | === 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; |
| | +----+---------+--------+------------+ |
| | | 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> |
|
| |
|
| 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:
| | 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> ALTER USER 'root'@'localhost' IDENTIFIED BY '''new_password'''; | | === 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) |
|
| |
|
| 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.
| | 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 sind ein paar nützliche Dinge, die Sie bei der Verwendung des '''mysql'''-Clients beachten sollten:
| | === Hinzufügen oder Löschen einer Spalte 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/alter-table.html ALTER TABLE...ADD] Anweisung, um eine Spalte hinzuzufügen |
| * 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 z.B |
| * 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. | | * 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> |
|
| |
|
| Um die Verbindung mit dem MySQL-Server zu trennen, geben Sie <tt>QUIT</tt> oder <tt>\q</tt> auf dem Client ein:
| | 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> QUIT
| | [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 |
| | *************************** 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) |
| | </syntaxhighlight> |
|
| |
|
| == Einige grundlegende Operationen mit MySQL == | | 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 |
|
| |
|
| 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.
| | 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> |
|
| |
|
| Vorhandene Datenbanken anzeigen. Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/show-databases.html SHOW DATABASES] Anweisung:
| | 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 |
| |
| | sys |
| |
| +--------------------+
| |
| 4 rows in set (0.00 sec)
| |
| | |
| Erstellen einer neuen Datenbank. Verwenden Sie eine [https://dev.mysql.com/doc/refman/8.0/en/create-database.html 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 [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. 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. 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. 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. 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 .
| |
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