One place for hosting & domains

      Nutzung

      Nutzung von SFTP zur sicheren Übertragung von Dateien mit einem Remote-Server


      Einführung

      FTP oder „File Transfer Protocol“ (Dateiübertragungsprotokoll) war eine beliebte unverschlüsselte Methode zur Übertragung von Dateien zwischen zwei Remote-Systemen.

      SFTP, das für SSH File Transfer Protocol (SSH-Dateiübertragungsprotokoll) oder Secure File Transfer Protocol (sicheres Dateiübertragungsprotokoll) steht, ist ein separates Protokoll, das mit SSH verpackt ist und auf ähnliche Weise funktioniert, jedoch über eine sichere Verbindung. Der Vorteil ist die Fähigkeit zur Nutzung einer sicheren Verbindung zur Übertragung von Dateien und zum Durchlaufen des Dateisystems sowohl auf dem lokalen als auch auf dem Remote-System.

      In fast allen Fällen ist SFTP aufgrund der zugrunde liegenden Sicherheitsfunktionen und der Fähigkeit, eine SSH-Verbindung einzubinden, gegenüber FTP vorzuziehen. FTP ist ein unsicheres Protokoll, das nur in begrenzten Fällen oder auf Netzwerken verwendet werden sollte, denen Sie vertrauen.

      Obwohl SFTP in viele grafische Tools integriert ist, wird in diesem Leitfaden die Verwendung über die interaktive Befehlszeilenschnittstelle demonstriert.

      Verbindung mit SFTP

      Standardmäßig verwendet SFTP das SSH-Protokoll, um eine sichere Verbindung zu authentifizieren und zu erstellen. Aus diesem Grund sind die gleichen Authentifizierungsmethoden verfügbar, die auch in SSH vorhanden sind.

      Obwohl Passwörter einfach zu verwenden und standardmäßig eingerichtet sind, empfehlen wir Ihnen, SSH-Schlüssel zu erstellen und Ihren öffentlichen Schlüssel auf jedes System zu übertragen, auf das Sie zugreifen müssen. Dies ist wesentlich sicherer und kann Ihnen auf lange Sicht Zeit sparen.

      Bitte sehen Sie sich diesen Leitfaden zur Einrichtung von SSH-Schlüsseln für den Zugriff auf Ihren Server an, wenn Sie dies noch nicht getan haben.

      Wenn Sie über SSH eine Verbindung zu dem Rechner herstellen können, haben Sie alle notwendigen Voraussetzungen erfüllt, um SFTP zur Verwaltung von Dateien zu verwenden. Testen Sie den SSH-Zugriff mit dem folgenden Befehl:

      • ssh sammy@your_server_ip_or_remote_hostname

      Wenn dies funktioniert, geben Sie zum Verlassen Folgendes ein:

      Jetzt können wir eine SFTP-Sitzung aufbauen, indem wir den folgenden Befehl ausgeben:

      • sftp sammy@your_server_ip_or_remote_hostname

      Sie stellen eine Verbindung zum Remote-System her, und Ihre Eingabeaufforderung ändert sich in eine SFTP-Eingabeaufforderung.

      Wenn Sie an einem benutzerdefinierten SSH-Port arbeiten (nicht dem Standard-Port 22), können Sie eine SFTP-Sitzung wie folgt öffnen:

      • sftp -oPort=custom_port sammy@your_server_ip_or_remote_hostname

      Dadurch werden Sie über den von Ihnen angegebenen Port mit dem Remote-System verbunden.

      Hilfe in SFTP erhalten

      Der nützlichste Befehl, den Sie zuerst lernen sollten, ist der Hilfebefehl. Damit haben Sie Zugriff auf eine Zusammenfassung der SFTP-Hilfe. Sie können sie aufrufen, indem Sie einen der folgenden Befehle in die Eingabeaufforderung eingeben:

      oder

      Damit wird eine Liste der verfügbaren Befehle angezeigt:

      Output

      Available commands: bye Quit sftp cd path Change remote directory to 'path' chgrp grp path Change group of file 'path' to 'grp' chmod mode path Change permissions of file 'path' to 'mode' chown own path Change owner of file 'path' to 'own' df [-hi] [path] Display statistics for current directory or filesystem containing 'path' exit Quit sftp get [-Ppr] remote [local] Download file help Display this help text lcd path Change local directory to 'path' . . .

      Einige der angezeigten Befehle werden wir in den folgenden Abschnitten näher betrachten.

      Wir können durch die Dateihierarchie des Remote-Systems navigieren, indem wir eine Reihe von Befehlen verwenden, die ähnlich wie ihre Shell-Gegenstücke funktionieren.

      Orientieren wir uns zunächst, indem wir herausfinden, in welchem Verzeichnis wir uns derzeit im Remote-System befinden. Genau wie in einer typischen Shell-Sitzung können wir Folgendes eingeben, um das aktuelle Verzeichnis zu erhalten:

      Output

      Remote working directory: /home/demouser

      Wir können den Inhalt des aktuellen Verzeichnisses des Remote-Systems mit einem anderen vertrauten Befehl anzeigen:

      Output

      Summary.txt info.html temp.txt testDirectory

      Beachten Sie, dass die Befehle innerhalb der SFTP-Schnittstelle nicht die normalen Shell-Befehle sind und nicht so funktionsreich sind, aber sie implementieren einige der wichtigeren optionalen Flags:

      Output

      drwxr-xr-x 5 demouser demouser 4096 Aug 13 15:11 . drwxr-xr-x 3 root root 4096 Aug 13 15:02 .. -rw------- 1 demouser demouser 5 Aug 13 15:04 .bash_history -rw-r--r-- 1 demouser demouser 220 Aug 13 15:02 .bash_logout -rw-r--r-- 1 demouser demouser 3486 Aug 13 15:02 .bashrc drwx------ 2 demouser demouser 4096 Aug 13 15:04 .cache -rw-r--r-- 1 demouser demouser 675 Aug 13 15:02 .profile . . .

      Um in ein anderes Verzeichnis zu gelangen, können wir diesen Befehl ausgeben:

      Wir können nun das Remote-Dateisystem durchlaufen, aber was, wenn wir auf unser lokales Dateisystem zugreifen müssen? Wir können Befehle auf das lokale Dateisystem richten, indem wir ihnen ein l für lokal voranstellen.

      Alle bisher besprochenen Befehle haben lokale Entsprechungen. Wir können das lokale Arbeitsverzeichnis ausgeben:

      Output

      Local working directory: /Users/demouser

      Wir können den Inhalt des aktuellen Verzeichnisses auf dem lokalen Rechner auflisten:

      Output

      Desktop local.txt test.html Documents analysis.rtf zebra.html

      Wir können auch das Verzeichnis wechseln, mit dem wir auf dem lokalen System interagieren möchten:

      Übertragung von Dateien mit SFTP

      Das Navigieren der Remote- und lokalen Dateisysteme ist nur von begrenztem Nutzen, wenn keine Möglichkeit besteht, Dateien zwischen den beiden Systemen zu übertragen.

      Übertragung von Remote-Dateien auf das lokale System

      Wenn wir Dateien von unserem Remote-Host herunterladen möchten, können wir dies tun, indem wir den folgenden Befehl ausgeben:

      Output

      Fetching /home/demouser/remoteFile to remoteFile /home/demouser/remoteFile 100% 37KB 36.8KB/s 00:01

      Wie Sie sehen können, lädt der Befehl get eine Remote-Datei in eine Datei mit dem gleichen Namen auf dem lokalen Dateisystem herunter.

      Wir können die Remote-Datei unter einem anderen Namen kopieren, indem wir den Namen anschließend angeben:

      Der Befehl get nimmt auch einige Options-Flags an. Beispielsweise können wir ein Verzeichnis und seinen gesamten Inhalt kopieren, indem wir die Option rekursiv angeben:

      Wir können SFTP anweisen, die entsprechenden Berechtigungen und Zugriffszeiten beizubehalten, indem wir das Flag -P oder -p verwenden:

      Übertragung lokaler Dateien auf das Remote-System

      Die Übertragung von Dateien auf das Remote-System lässt sich ebenso einfach mit dem entsprechend benannten Befehl „put“ erreichen:

      Output

      Uploading localFile to /home/demouser/localFile localFile 100% 7607 7.4KB/s 00:00

      Die gleichen Flags, die mit get funktionieren, gelten auch für put. Um also ein vollständiges lokales Verzeichnis zu kopieren, können Sie ausgeben:

      Anmerkung: In den Versionen von OpenSSH, die mit aktuellen Ubuntu-Versionen (zumindest 14.04 bis 15.10) ausgeliefert werden, gibt es derzeit einen Fehler, der verhindert, dass der obige Befehl korrekt funktioniert. Wenn Sie den obigen Befehl ausgeben, um Inhalte auf einen Server zu übertragen, der die fehlerhafte Version von OpenSSH verwendet, wird der folgende Fehler ausgegeben: Couldn't canonicalise: No such file or directory (Keine Kanonisierung möglich: keine solche Datei oder solches Verzeichnis).

      Um dieses Problem zu umgehen, erstellen Sie zuerst das Zielverzeichnis auf der Remote-Seite, indem Sie mkdir localDirectory eingeben. Anschließend sollte der obige Befehl ohne Fehler abschließen.

      Ein bekanntes Tool, das beim Herunterladen und Hochladen von Dateien nützlich ist, ist der Befehl df, der ähnlich wie die Kommandozeilenversion funktioniert. Damit können Sie überprüfen, ob Sie über ausreichend Speicherplatz verfügen, um die gewünschten Übertragungen durchzuführen:

      Output

      Size Used Avail (root) %Capacity 19.9GB 1016MB 17.9GB 18.9GB 4%

      Bitte beachten Sie, dass es keine lokale Variante dieses Befehls gibt, jedoch können wir dies umgehen, indem wir den Befehl ! eingeben.

      Der Befehl ! versetzt uns in eine lokale Shell, in der wir jeden auf unserem lokalen System verfügbaren Befehl ausführen können. Wir können die Festplattennutzung überprüfen, indem wir Folgendes eingeben:

      und dann

      Output

      Filesystem Size Used Avail Capacity Mounted on /dev/disk0s2 595Gi 52Gi 544Gi 9% / devfs 181Ki 181Ki 0Bi 100% /dev map -hosts 0Bi 0Bi 0Bi 100% /net map auto_home 0Bi 0Bi 0Bi 100% /home

      Jeder andere lokale Befehl wird wie erwartet funktionieren. Um zu Ihrer SFTP-Sitzung zurückzukehren, geben Sie Folgendes ein:

      Sie sollten nun wieder die SFTP-Eingabeaufforderung sehen.

      Einfache Dateimanipulation mit SFTP

      Mit SFTP können Sie die Art der grundlegenden Dateiwartung durchführen, die bei der Arbeit mit Dateihierarchien nützlich ist.

      Beispielsweise können Sie den Eigentümer einer Datei auf dem Remote-System ändern:

      Beachten Sie, dass der SFTP-Befehl im Gegensatz zum Systembefehl chmod keine Benutzernamen akzeptiert, sondern stattdessen UIDs verwendet. Leider gibt es keine einfache Möglichkeit, die entsprechende UID innerhalb der SFTP-Schnittstelle zu kennen.

      Eine aufwändige Umgehung könnte erreicht werden mit:

      • get /etc/passwd
      • !less passwd

      Output

      root:x:0:0:root:/root:/bin/bash daemon:x:1:1:daemon:/usr/sbin:/bin/sh bin:x:2:2:bin:/bin:/bin/sh sys:x:3:3:sys:/dev:/bin/sh sync:x:4:65534:sync:/bin:/bin/sync games:x:5:60:games:/usr/games:/bin/sh man:x:6:12:man:/var/cache/man:/bin/sh . . .

      Beachten Sie, dass wir den Befehl ! nicht für sich allein gegeben haben, sondern als Präfix für einen lokalen Shell-Befehl verwendet haben. Dies funktioniert, um jeden Befehl auszuführen, der auf unserem lokalen Rechner verfügbar ist, und hätte zuvor mit dem lokalen Befehl df verwendet werden können.

      Die UID wird in der dritten Spalte der Datei stehen, die durch Doppelpunkt abgegrenzt ist.

      Auf ähnliche Weise können wir den Gruppeneigentümer einer Datei ändern mit:

      Auch hier gibt es keine einfache Möglichkeit, eine Auflistung der Gruppen des Remote-Systems zu erhalten. Wir können dies mit dem folgenden Befehl umgehen:

      • get /etc/group
      • !less group

      Output

      root:x:0: daemon:x:1: bin:x:2: sys:x:3: adm:x:4: tty:x:5: disk:x:6: lp:x:7: . . .

      Die dritte Spalte enthält die ID der Gruppe, die mit dem Namen in der ersten Spalte verknüpft ist. Das ist, wonach wir suchen.

      Zum Glück funktioniert der Befehl chmod wie erwartet auf dem Remote-Dateisystem:

      Output

      Changing mode on /home/demouser/publicFile

      Es gibt keinen Befehl zur Manipulation lokaler Dateiberechtigungen, aber Sie können die lokale umask festlegen, sodass alle auf das lokale System kopierten Dateien die entsprechenden Berechtigungen aufweisen.

      Das kann mit dem Befehl lumask geschehen:

      Output

      Local umask: 022

      Jetzt haben alle regulären Dateien, die heruntergeladen werden (solange das Flag -p nicht verwendet wird) 644 Berechtigungen.

      Mit SFTP können Sie Verzeichnisse sowohl auf lokalen als auch auf Remote-Systemen mit lmkdir bzw. mkdir erstellen. Diese funktionieren wie erwartet.

      Der Rest der Dateibefehle zielt nur auf das Remote-Dateisystem ab:

      Diese Befehle replizieren das grundlegende Verhalten der Shell-Versionen. Wenn Sie diese Aktionen auf dem lokalen Dateisystem ausführen müssen, denken Sie daran, dass Sie durch Ausgabe des folgenden Befehls in eine Shell wechseln können:

      Oder führen Sie einen einzelnen Befehl auf dem lokalen System aus, indem Sie dem Befehl das ! voranstellen, wie hier:

      Wenn Sie mit Ihrer SFTP-Sitzung fertig sind, verwenden Sie exit oder bye, um die Verbindung zu schließen.

      Zusammenfassung

      Obwohl SFTP ein einfaches Tool ist, ist es sehr nützlich für die Verwaltung von Servern und die Übertragung von Dateien zwischen ihnen.

      Beispielsweise können Sie SFTP verwenden, um bestimmten Benutzern die Übertragung von Dateien ohne SSH-Zugriff zu ermöglichen. Weitere Informationen zu diesem Vorgang finden Sie in unserem Tutorial Aktivieren von SFTP ohne Shell-Zugriff.

      Wenn Sie gewohnt sind, FTP oder SCP für Ihre Übertragungen zu verwenden, ist SFTP eine gute Möglichkeit, die Stärken beider zu nutzen. Obwohl es nicht für jede Situation geeignet ist, ist es ein flexibles Tool, das Sie in Ihrem Repertoire haben sollten.



      Source link

      Installation und Nutzung von PostgreSQL auf Ubuntu 18.04


      Einführung

      Relationale Datenbank-Managementsysteme sind ein wichtiger Bestandteil zahlreicher Websites und Anwendungen. Sie stellen eine strukturierte Art und Weise zur Speicherung, Organisation und zum Zugriff auf Informationen bereit.

      PostgreSQL oder Postgres ist ein relationales Datenbank-Managementsystem, das eine Implementierung der SQL-Abfragesprache ermöglicht. Es ist eine beliebte Wahl für viele kleine und große Projekte und hat den Vorteil, dass sie standardkonform ist und zahlreiche fortgeschrittene Funktionen, wie zuverlässige Transaktionen und Parallelität, ohne Leseschutz aufweist.

      Dieser Leitfaden beschreibt die Installation von Postgres auf einer Ubuntu 18.04 VPS-Instanz und enthält auch Anweisungen für die grundlegende Datenbankverwaltung.

      Voraussetzungen

      Um diesem Tutorial zu folgen, benötigen Sie einen Ubuntu 18.04 Server, der im Sinne unseres Leitfadens Ersteinrichtung eines Servers mit Ubuntu 18.04 konfiguriert wurde. Nach Abschluss der Voraussetzungen dieses Tutorials sollte Ihr Server einen Benutzer ohne Root-, aber mit sudo-Berechtigung und eine einfache Firewall haben.

      Schritt 1 — Installation von PostgreSQL

      Ubuntu Standard-Repositorys enthalten Postgres-Pakete, damit Sie diese mit dem apt-Paketsystem installieren können.

      Und weil Sie apt in dieser Sitzung das erste Mal verwenden, sollten Sie Ihren lokalen Paketindex aktualisieren. Installieren Sie dann das Postgres-Paket mit dem -contrib-Paket, das zusätzliche Hilfsprogramme und Funktionalität hinzufügt:

      • sudo apt update
      • sudo apt install postgresql postgresql-contrib

      Nachdem jetzt die Software installiert ist, können wir die Funktionsweise besprechen und auch wie sie sich möglicherweise von anderen Datenbank-Managementsystemen unterscheidet, die Sie verwendet haben.

      Schritt 2 — Nutzung von PostgreSQL-Rollen und Datenbanken

      Postgres verwendet zum Umgang mit Authentifizierung und Autorisierung standardmäßig ein Konzept namens „Rollen“. Diese sind auf gewisse Art und Weise herkömmlichen Konten im Unix-Stil ähnlich, aber Postgres unterscheidet nicht zwischen Benutzern und Gruppen und bevorzugt eher den flexiblen Begriff „Rolle“.

      Nach der Installation verwendet Postgres ident-Authentifizierung. Das bedeutet, dass es Postgres-Rollen mit einem übereinstimmenden Unix/Linux-Systemkonto verknüpft. Falls eine Rolle in Postgres existiert, kann sich ein Unix/Linux-Benutzername mit demselben Namen als diese Rolle anmelden.

      Das Installationsverfahren hat ein Benutzerkonto namens Postgres erstellt, das mit der Standard-Postgres-Rolle verknüpft ist. Um Postgres zu verwenden, können Sie sich bei diesem Konto anmelden.

      Es gibt mehrere Möglichkeiten, um dieses Konto zum Zugriff auf Postgres zu verwenden.

      Wechsel zum Postgres-Konto

      Wechseln Sie auf Ihrem Server zum Postgres-Konto, indem Sie Folgendes eingeben:

      Sie können jetzt sofort auf eine Postgres-Eingabeaufforderung zugreifen, indem Sie Folgendes eingeben:

      Damit melden Sie sich bei der PostgreSQL-Eingabeaufforderung an und von hier aus können Sie sofort mit dem Datenbank-Managementsystem arbeiten.

      Beenden Sie die PostgreSQL-Eingabeaufforderung durch die Eingabe von:

      Damit kehren Sie zur Postgres Linux-Eingabeaufforderung zurück.

      Zugriff auf eine Postgres-Eingabeaufforderung ohne Kontowechsel

      Sie können den gewünschten Befehl auch mit dem Postgres-Konto direkt mit sudo ausführen.

      So wurden Sie z. B. im letzten Beispiel angewiesen, zur Postgres-Eingabeaufforderung zu gelangen, indem Sie zunächst auf den Postgres-Benutzer wechseln und dann psql ausführen, um die Postgres-Eingabeaufforderung zu öffnen. Sie könnten dies in einem Schritt ausführen, indem Sie den einzelnen psql-Befehl als Postgres-Benutzer mit sudo ausführen, wie zum Beispiel:

      Damit melden Sie sich direkt in Postgres ohne die zwischengeschaltete Bash Shell an.

      Sie können die interaktive Postgres-Sitzung beenden, indem Sie Folgendes eingeben:

      Zahlreiche Anwendungsfälle erfordern mehr als eine Postgres-Rolle. Lesen Sie weiter, um mehr zu deren Konfiguration zu erfahren.

      Schritt 3 — Erstellen einer neuen Rolle

      Sie haben momentan nur die** Postgres**-Rolle innerhalb der Datenbank konfiguriert. Mit dem Befehl createrole können Sie neue Rollen von der Befehlszeile aus erstellen. Die --interactive Flag fordert Sie dazu auf, den Namen der neuen Rolle einzugeben und fragt Sie auch, ob diese Superuser-Berechtigung erhalten sollte.

      Wenn Sie als Postgres-Konto angemeldet sind, können Sie einen neuen Benutzer erstellen, indem Sie Folgendes eingeben:

      Wenn Sie allerdings lieber sudo für jeden Befehl verwenden, ohne Ihr normales Konto zu wechseln, verwenden Sie bitte Folgendes:

      • sudo -u postgres createuser --interactive

      Das Skript enthält einige Auswahlmöglichkeiten und führt die korrekten Postgres-Befehle basierend auf Ihren Antworten aus, um einen Benutzer im Sinne Ihrer Spezifikationen zu erstellen.

      Output

      Enter name of role to add: sammy Shall the new role be a superuser? (y/n) y

      Sie können mehr Kontrolle erhalten, indem Sie einige zusätzliche Flags übergeben. Sehen Sie sich die Optionen auf der man-Seite an:

      Ihre Installation von Postgres hat jetzt einen neuen Benutzer, aber Sie haben noch keine Datenbanken hinzugefügt. Der nächste Abschnitt beschreibt diesen Vorgang.

      Schritt 4 — Erstellen einer neuen Datenbank

      Eine andere, standardmäßige Annahme des Postgres-Authentifizierungssystems ist, dass mit jeder Rolle, die zur Anmeldung verwendet wird, eine gleichnamige Datenbank verknüpft ist, auf die diese Rolle zugreifen kann.

      Wenn der von Ihnen im letzten Abschnitt erstellte Benutzer Sammy heißt, wird diese Rolle demnach versuchen, standardmäßig eine Verbindung mit einer Datenbank namens „Sammy“ herzustellen. Sie können die entsprechende Datenbank mit dem Befehl createdb erstellen.

      Wenn Sie als Postgres-Konto angemeldet sind, sollten Sie Folgendes eingeben:

      Wenn Sie allerdings lieber sudo für jeden Befehl verwenden, ohne Ihr normales Konto zu wechseln, verwenden Sie bitte Folgendes:

      • sudo -u postgres createdb sammy

      Diese Flexibilität liefert mehrere Möglickkeiten, um je nach Bedarf Datenbanken zu erstellen.

      Schritt 5 — Eröffnen einer Postgres-Eingabeaufforderung mit der neuen Rolle

      Um sich mit der ident-basierten Authentifizierung anzumelden, benötigen Sie einen Linux-Benutzer mit dem gleichen Namen wie Ihre Postgres-Rolle und -Datenbank.

      Wenn Sie keinen passenden Linux-Benutzer zur Verfügung haben, können Sie mit dem Befehl adduser einen erstellen. Sie müssen dies von Ihrem Konto ohne root-Berechtigung mit sudo-Privilegien vornehmen (d. h. Sie können nicht als postgres-Benutzer angemeldet sein):

      Sobald dieses neue Konto verfügbar ist, können Sie entweder die Datenbank wechseln und sich mit ihr verbinden, indem Sie Folgendes eingeben:

      Oder Sie können Folgendes Inline vornehmen:

      Mit diesem Befehl melden Sie sich automatisch an, vorausgesetzt, dass alle Komponenten ordnungsgemäß konfiguriert wurden.

      Wenn Ihr Benutzer sich mit einer anderen Datenbank verbinden soll, können Sie dies tun, indem Sie die Datenbank wie folgt angeben:

      Sobald Sie angemeldet sind, können Sie Ihre aktuellen Verbindungsinformationen überprüfen, indem Sie Folgendes eingeben:

      Output

      You are connected to database "sammy" as user "sammy" via socket in "/var/run/postgresql" at port "5432".

      Das ist nützlich, wenn Sie eine Verbindung mit nicht standardmäßigen Datenbanken oder mit nicht standardmäßigen Benutzern vornehmen.

      Schritt 6 — Erstellen und Löschen von Tabellen

      Da Sie nun wissen, wie Sie eine Verbindung mit dem PostgreSQL -Datenbanksystem herstellen, können Sie einige grundlegende Postgres-Managementaufgaben lernen.

      Erstellen Sie zunächst eine Tabelle zum Speichern von Daten, wie zum Beispiel eine Tabelle, die Spielplatzgeräte beschreibt.

      Die grundlegende Syntax für diesen Befehl lautet wie folgt:

      CREATE TABLE table_name (
          column_name1 col_type (field_length) column_constraints,
          column_name2 col_type (field_length),
          column_name3 col_type (field_length)
      );
      

      Wie Sie sehen, geben diese Befehle der Tabelle einen Namen, definieren dann die Spalten sowie den Spaltentyp und die maximale Länge der Felddaten. Sie können auch wahlweise Beschränkungen für jede Spalte angeben.

      Sie können hier mehr über das Erstellen und Verwalten von Tabellen in Postgres erfahren.

      Erstellen Sie zur Veranschaulichung eine einfache Tabelle wie folgt:

      CREATE TABLE playground (
          equip_id serial PRIMARY KEY,
          type varchar (50) NOT NULL,
          color varchar (25) NOT NULL,
          location varchar(25) check (location in ('north', 'south', 'west', 'east', 'northeast', 'southeast', 'southwest', 'northwest')),
          install_date date
      );
      

      Mit diesen Befehlen erstellen Sie eine Tabelle, mit der Spielplatzgeräte erfasst werden. Das beginnt mit einer Geräte-ID vom Typ Serie. Der Datentyp ist eine automatisch steigende Ganzzahl. Sie haben dieser Spalte auch die Primärschlüssel-Einschränkung gegeben, was bedeutet, dass die Werte einzigartig sein müssen und nicht Null sein dürfen.

      Für zwei Spalten (equip_id und install_date) geben die Befehle keine Feldlänge vor. Das liegt daran, dass für einige Spalten keine bestimmte Länge vorgegeben wird, weil die Länge durch den Typ bestimmt wird.

      Die nächsten beiden Befehle erstellen Spalten für den Typ bzw. die Farbe des Geräts, die beide nicht leer sein können. Der nächste Befehl erstellt eine location-Spalte für den Standort und eine Einschränkung, die vorschreibt, dass der Wert einer von acht möglichen Werten anzeigt. Der letzte Befehl erstellt eine Datumsspalte, in der das Datum aufgezeichnet wird, an dem Sie die Geräte installiert haben.

      Zeigen Sie Ihre neue Tabelle an, indem Sie Folgendes eingeben:

      Output

      List of relations Schema | Name | Type | Owner --------+-------------------------+----------+------- public | playground | table | sammy public | playground_equip_id_seq | sequence | sammy (2 rows)

      Ihre Spielplatz-Tabelle ist hier, aber Sie sehen auch etwas namens playground_equip_id_seq, das die Typen-sequence angibt. Damit wird der Serientyp angegeben, den Sie Ihrer Spalte equip_id zugeordnet haben. Damit wird die nächste Nummer in der Sequenz aufgezeichnet. Der Serientyp wird automatisch für diese Art von Spalten erstellt.

      Wenn Sie nur die Tabelle, ohne die Sequenz, sehen möchten, können Sie Folgendes eingeben:

      Output

      List of relations Schema | Name | Type | Owner --------+------------+-------+------- public | playground | table | sammy (1 row)

      Schritt 7 — Hinzufügen, Abfrage und Löschen von Daten in einer Tabelle

      Jetzt können Sie Daten in die Tabelle einfügen.

      Sie können eine Rutschbahn und eine Schaukel hinzufügen, indem Sie die Tabelle aufrufen, der Sie diese Geräte hinzufügen möchten, die Spalten bezeichnen und dann Daten in jede Spalte eingeben, wie zum Beispiel:

      • INSERT INTO playground (type, color, location, install_date) VALUES ('slide', 'blue', 'south', '2017-04-28');
      • INSERT INTO playground (type, color, location, install_date) VALUES ('swing', 'yellow', 'northwest', '2018-08-16');

      Sie sollten bei der Eingabe der Daten darauf achten, einige häufige Fehler zu vermeiden. Setzen Sie den Spaltennamen zum Beispiel nicht in Anführungszeichen, aber die Spaltenwerte müssen mit Anführungszeichen eingegeben werden.

      Sie sollten auch bedenken, dass Sie keinen Wert für die Spalte equip_id eingeben dürfen. Dieser Wert wird automatisch beim Erstellen einer neuen Zeile in der Tabelle erstellt.

      Sie können die hinzugefügten Informationen mit der folgenden Eingabe abrufen:

      • SELECT * FROM playground;

      Output

      equip_id | type | color | location | install_date ----------+-------+--------+-----------+-------------- 1 | slide | blue | south | 2017-04-28 2 | swing | yellow | northwest | 2018-08-16 (2 rows)

      Hier können Sie sehen, dass Ihre equip_id erfolgreich ausgefüllt wurde und alle anderen Daten korrekt organisiert wurden.

      Wenn die Rutschbahn auf dem Spielplatz beschädigt wird und Sie diese entfernen müssen, können Sie auch die Zeile aus der Tabelle entfernen, indem Sie Folgendes eingeben:

      • DELETE FROM playground WHERE type = 'slide';

      Führen Sie eine erneute Abfrage der Tabelle durch:

      • SELECT * FROM playground;

      Output

      equip_id | type | color | location | install_date ----------+-------+--------+-----------+-------------- 2 | swing | yellow | northwest | 2018-08-16 (1 row)

      Sie werden dann sehen, dass Ihre Rutschbahn nicht mehr länger Teil der Tabelle ist.

      Schritt 8 — Hinzufügen und Löschen von Spalten aus einer Tabelle

      Nach Erstellen der Tabelle können Sie diese relativ einfach ändern, um Spalten hinzuzufügen oder zu entfernen. Fügen Sie eine Spalte hinzu, um den letzten Wartungsbesuch für jedes Gerät zu zeigen, indem Sie Folgendes eingeben:

      • ALTER TABLE playground ADD last_maint date;

      Wenn sie sich die Tabelleninformationen erneut ansehen, werden Sie sehen, dass eine neue Spalte hinzugefügt wurde (aber keine Daten eingegeben wurden).

      • SELECT * FROM playground;

      Output

      equip_id | type | color | location | install_date | last_maint ----------+-------+--------+-----------+--------------+------------ 2 | swing | yellow | northwest | 2018-08-16 | (1 row)

      Das Löschen einer Spalte ist ebenso einfach. Wenn Sie feststellen, dass Ihre Arbeitskräfte ein anderes Tool verwendet, um die Wartungsarbeiten aufzuzeichnen, können Sie die Spalte löschen, indem Sie Folgendes eingeben:

      • ALTER TABLE playground DROP last_maint;

      Damit werden die Spalte last_maint und alle darin enthaltenen Werte gelöscht, aber alle anderen Daten bleiben intakt.

      Schritt 9 — Aktualisieren der Daten in einer Tabelle

      Bisher haben Sie gelernt, wie man einer Tabelle Einträge hinzufügen und aus ihr löschen kann, aber dieses Tutorial hat noch nicht erklärt, wie man bestehende Einträge ändern kann.

      Sie können die Werte einer vorhandenen Eingabe aktualisieren, indem Sie den gewünschten Datensatz abfragen und die Spalte auf den Wert einstellen, den Sie verwenden möchten. Sie können eine Abfrage nach dem „Schaukel“-Datensatz vornehmen (damit erhalten Sie alle Einträge mit dem Wort Schaukel in der Tabelle) und Sie können die Farbe auf „rot“ ändern. Das könnte nützlich sein, wenn das Schaukelgerüst zum Beispiel neu lackiert werden muss:

      • UPDATE playground SET color = 'red' WHERE type = 'swing';

      Sie können verifizieren, dass die Arbeiten erfolgreich waren, indem Sie die Daten erneut abfragen:

      • SELECT * FROM playground;

      Output

      equip_id | type | color | location | install_date ----------+-------+-------+-----------+-------------- 2 | swing | red | northwest | 2010-08-16 (1 row)

      Wie Sie sehen, wird die Farbe der Schaukel jetzt als „rot“ angegeben.

      Zusammenfassung

      Sie haben jetzt PostgreSQL auf Ihrem Server Ubuntu 18.04 eingerichtet. Sie können allerdings noch *mehr *über Postgres lernen. Hier finden Sie einige Anleitungen zur Nutzung von Postgres:



      Source link