PostgreSQL Array: Funktionen, Typ, Beispiel
Was ist PostgreSQL Array?
In PostgreSQLkönnen wir eine Spalte als Array gültiger Datentypen definieren. Der Datentyp kann ein integrierter, benutzerdefinierter oder aufgezählter Typ sein. Darüber hinaus spielen Arrays eine wichtige Rolle PostgreSQL.
Jede entsprechende PostgreSQL Der Datentyp wird mit einem entsprechenden Array-Typ geliefert. Beispielsweise hat der Datentyp „Integer“ den Array-Typ „Integer[], der Datentyp „Character“ den Array-Typ „Character[] usw.
Erstellen PostgreSQL Arrays
Im folgenden Beispiel erstellen wir eine Tabelle mit dem Namen „Employees“, wobei die Spalte „Kontakt“ als Text-Array definiert ist:
CREATE TABLE Employees ( id int PRIMARY KEY, name VARCHAR (100), contact TEXT [] );
Der Befehl sollte erfolgreich ausgeführt werden.
Einsetzen PostgreSQL Array-Werte
Lass uns jetzt einfügen Werte in die obige Tabelle eintragen:
INSERT INTO Employees VALUES ( 1, 'Alice John', ARRAY [ '(408)-743-9045', '(408)-567-7834' ] );
Die Einfügung sollte erfolgreich verlaufen.
Die Werte der dritten Spalte, also Kontakt, wurden als Array eingefügt. Dies wurde durch die Verwendung des ARRAY-Konstruktors erreicht.
In diesem Beispiel haben wir sie in eckige Klammern [] eingeschlossen. Wir haben zwei Kontakte für die Mitarbeiterin Alice John.
Es ist uns weiterhin möglich, geschweifte Klammern {} zu verwenden, wie unten gezeigt:
INSERT INTO Employees VALUES ( 2, 'Kate Joel', '{"(408)-783-5731"}' ), ( 3, 'James Bush', '{"(408)-745-8965","(408)-567-78234"}' );
Der Befehl sollte erfolgreich ausgeführt werden.
Die obigen Anweisungen fügen zwei Zeilen in die Tabelle „Employees“ ein. Bei Verwendung von geschweiften Klammern wird das Array in einfache Anführungszeichen (') eingeschlossen, während die Textarrayelemente in doppelte Anführungszeichen (“) eingeschlossen werden.
Array-Daten abfragen
Um die Elemente eines Arrays abzufragen, verwenden wir die SELECT-Anweisung.
Um den Inhalt unserer Employees-Tabelle anzuzeigen, führen wir den folgenden Befehl aus:
SELECT * FROM Employees;
Dies gibt Folgendes zurück:
Die Elemente der Array-Spalte, also der Kontakt, wurden in geschweifte Klammern {} eingeschlossen.
Um auf die Array-Elemente selbst zuzugreifen, fügen wir einen Index in eckigen Klammern [] hinzu. Das erste Element in einem Array steht an Position 1.
Beispielsweise benötigen wir die Namen der Mitarbeiter und nur deren Erstkontakt für Mitarbeiter mit mehr als einem Kontakt. Wir können darauf als Kontakt[1] zugreifen.
Sehen wir uns das an:
SELECT name, contact[1] FROM Employees;
Dies gibt Folgendes zurück:
Wir können die SELECT-Anweisung zusammen mit der WHERE-Klausel verwenden, um Zeilen basierend auf der Array-Spalte zu filtern.
Um beispielsweise den Mitarbeiter mit (408)-567-78234 als zweiten Kontakt anzuzeigen, können wir den folgenden Befehl ausführen:
SELECT name FROM Employees WHERE contact [ 2 ] = '(408)-567-78234';
Dies gibt Folgendes zurück:
Ändern PostgreSQL Feld
Sie können alle oder ein einzelnes Element eines Arrays aktualisieren.
Hier ist der Inhalt der Mitarbeitertabelle:
Aktualisieren wir die zweite Telefonnummer des Mitarbeiters James Bush, dessen ID 3 ist:
Führen Sie den folgenden Befehl aus:
UPDATE Employees SET contact [ 2 ] = '(408)-589-89347' WHERE id = 3;
Der Befehl sollte erfolgreich ausgeführt werden:
Lassen Sie uns die Tabelle abfragen, um zu überprüfen, ob die Änderung erfolgreich war:
Der Wechsel war erfolgreich.
Suche in einem PostgreSQL Feld
Derzeit sieht unsere Mitarbeitertabelle wie folgt aus:
Angenommen, wir müssen wissen, wem der Kontakt (408)-783-5731 gehört, unabhängig von der Position innerhalb des Kontaktarrays, können wir die Funktion ANY() wie unten gezeigt verwenden:
SELECT name, contact FROM Employees WHERE '(408)-783-5731' = ANY (contact);
Dies gibt Folgendes zurück:
Arrays erweitern
Wir können die Werte eines Arrays in Zeilen aufteilen. Dieser Vorgang wird als Array-Erweiterung bezeichnet.
Im Beispiel der Tabelle „Employees“ gibt es einige Mitarbeiter mit zwei Kontakten im Kontaktarray. Wir können diese in separate Zeilen aufteilen.
PostgreSQL stellt die Funktion unnest() bereit, die hierfür verwendet werden kann.
Beispielsweise:
SELECT name, unnest(contact) FROM Employees;
Dies gibt Folgendes zurück:
Die Mitarbeiter Alice John und James Bush haben zwei Ansprechpartner. Wir können in separate Reihen aufteilen.
Verwenden von pgAdmin
Erstellen PostgreSQL Arrays
Um dasselbe über pgAdmin zu erreichen, gehen Sie wie folgt vor:
Schritt 1) Melden Sie sich bei Ihrem pgAdmin-Konto an.
Schritt 2)
- Klicken Sie in der Navigationsleiste auf der linken Seite auf „rbases“.
- Klicken Sie auf die Schaltfläche Demo
Schritt 3) Geben Sie die Abfrage in den Abfrageeditor ein, um die Tabelle „Employees“ zu erstellen:
CREATE TABLE Employees ( id int PRIMARY KEY, name VARCHAR (100), contact TEXT [] );
Schritt 4) Klicken Sie auf die Schaltfläche „Ausführen“.
Einsetzen PostgreSQL Array-Werte
Schritt 1) Geben Sie die folgende Abfrage in den Abfrage-Editor ein:
INSERT INTO Employees VALUES ( 1, 'Alice John', ARRAY [ '(408)-743-9045', '(408)-567-7834' ] );
Schritt 2) Klicken Sie auf die Schaltfläche „Ausführen“:
Schritt 3)
Um geschweifte Klammern in der Abfrage zu verwenden
Schritt 1) Geben Sie die folgende Abfrage in den Abfrage-Editor ein:
INSERT INTO Employees VALUES ( 2, 'Kate Joel', '{"(408)-783-5731"}' ), ( 3, 'James Bush', '{"(408)-745-8965","(408)-567-78234"}' );
Schritt 2) Klicken Sie auf die Schaltfläche „Ausführen“:
Array-Daten abfragen
Schritt 1) Um den Inhalt der Tabelle „Employees“ anzuzeigen, geben Sie die folgende Abfrage im Abfrage-Editor ein:
SELECT * FROM Employees;
Schritt 2) Klicken Sie auf die Schaltfläche „Ausführen“:
Es sollte Folgendes zurückgeben:
Schritt 3) So sehen Sie die ersten Kontakte von Mitarbeitern:
- Geben Sie die folgende Abfrage in den Abfrage-Editor ein:
SELECT name, contact[1] FROM Employees;
- Klicken Sie auf die Schaltfläche „Ausführen“.
Es sollte Folgendes zurückgeben:
Schritt 4) So kombinieren Sie die SELECT-Anweisung mit der WHERE-Klausel:
- Geben Sie den folgenden Befehl im Abfrage-Editor ein:
SELECT name FROM Employees WHERE contact [ 2 ] = '(408)-567-78234';
- Klicken Sie auf die Schaltfläche „Ausführen“.
Es sollte Folgendes zurückgeben:
Ändern PostgreSQL Feld
Schritt 1) Um den zweiten Kontakt des Benutzers mit der ID 3 zu aktualisieren, führen Sie den folgenden Befehl aus:
UPDATE Employees SET contact [ 2 ] = '(408)-589-89347' WHERE id = 3;
Schritt 2) Klicken Sie auf die Schaltfläche „Ausführen“.
Schritt 3)
1.Geben Sie den folgenden Befehl im Abfrage-Editor ein, um zu überprüfen, ob die Änderung erfolgreich war:
SELECT * FROM Employees;
2.Klicken Sie auf die Schaltfläche „Ausführen“.
Es sollte Folgendes zurückgeben:
Suche in einem PostgreSQL Feld
Schritt 1) Geben Sie die folgende Abfrage in den Abfrage-Editor ein:
SELECT name, contact FROM Employees WHERE '(408)-783-5731' = ANY (contact);
Schritt 2) Klicken Sie auf die Schaltfläche „Ausführen“.
Es sollte Folgendes zurückgeben:
Arrays erweitern
Schritt 1) Geben Sie die folgende Abfrage in den Abfrage-Editor ein:
SELECT name, unnest(contact) FROM Employees;
Schritt 2) Klicken Sie auf die Schaltfläche „Ausführen“.
Es sollte Folgendes zurückgeben:
Zusammenfassung
- PostgreSQL ermöglicht es uns, eine Tabellenspalte als Array-Typ zu definieren.
- Das Array muss gültig sein Datentyp wie Ganzzahl-, Zeichen- oder benutzerdefinierte Typen.
- Um Werte in eine Array-Spalte einzufügen, verwenden wir den ARRAY-Konstruktor.
- Befinden sich mehr als ein Element in derselben Zeile einer Array-Spalte, befindet sich das erste Element an Position 1.
- Auf jeden Wert kann zugegriffen werden, indem ein Index in eckigen Klammern [] übergeben wird.
- Die Elemente des Arrays können mit der SELECT-Anweisung abgerufen werden.
- Die Werte der Array-Spalte können in eckige Klammern [] oder geschweifte Klammern {} eingeschlossen werden.
- Mit der Funktion ANY() können wir nach Array-Spaltenwerten suchen.
Laden Sie die in diesem Tutorial verwendete Datenbank herunter