Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
AWS IoT TwinMaker Knowledge Graph, zusätzliche Ressourcen
Dieser Abschnitt enthält grundlegende Beispiele für die PartiQL-Syntax, die zum Schreiben von Abfragen im Knowledge Graph verwendet wird, sowie Links zur PartiQL-Dokumentation, die Informationen zum Knowledge Graph-Datenmodell enthält.
Diese Reihe von Beispielen zeigt grundlegende Abfragen mit ihren Antworten. Verwenden Sie dies als Referenz, um Ihre eigenen Abfragen zu schreiben.
- Grundlegende Abfragen
-
-
Ruft alle Entitäten mit einem Filter ab
SELECT entity FROM EntityGraph MATCH (entity) WHERE entity.entityName = 'room_0'Diese Abfrage gibt alle Entitäten in einem Workspace mit dem Namen zurück
room_0.FROMKlausel:EntityGraphist die Grafiksammlung, die alle Entitäten und ihre Beziehungen in einem Workspace enthält. Diese Sammlung wird automatisch auf der AWS IoT TwinMaker Grundlage der Entitäten in Ihrem Workspace erstellt und verwaltet.MATCHKlausel: gibt ein Muster an, das einem Teil des Diagramms entspricht. In diesem Fall(entity)entspricht das Muster jedem Knoten im Diagramm und ist an die Entitätsvariable gebunden. Auf dieFROMKlausel muss dieMATCHKlausel folgen.WHEREKlausel: gibt einen Filter für dasentityNameFeld des Knotens an, mit dem der Wert übereinstimmen mussroom_0.SELECTKlausel: spezifiziert dieentityVariable, sodass der gesamte Entitätsknoten zurückgegeben wird.Antwort:
{ "columnDescriptions": [ { "name": "entity", "type": "NODE" } ], "rows": [ { "rowData": [ { "arn": "arn:aws:iottwinmaker:us-east-1: 577476956029: workspace / SmartBuilding8292022 / entity / room_18f3ef90 - 7197 - 53 d1 - abab - db9c9ad02781 ", "creationDate": 1661811123914, "entityId": "room_18f3ef90-7197-53d1-abab-db9c9ad02781", "entityName": "room_0", "lastUpdateDate": 1661811125072, "workspaceId": "SmartBuilding8292022", "description": "", "components": [ { "componentName": "RoomComponent", "componentTypeId": "com.example.query.construction.room", "properties": [ { "propertyName": "roomFunction", "propertyValue": "meeting" }, { "propertyName": "roomNumber", "propertyValue": 0 } ] } ] } ] } ] }Die
columnDescriptionsgibt Metadaten über die Spalte zurück, z. B. den Namen und den Typ. Der zurückgegebene Typ istNODE. Dies zeigt an, dass der gesamte Knoten zurückgegeben wurde. Andere Werte für den Typ können seinEDGE, die auf eine Beziehung hinweisen würdenVALUE, oder die auf einen Skalarwert hinweisen würden, z. B. eine Ganzzahl oder eine Zeichenfolge.Das
rowsgibt eine Liste von Zeilen zurück. Da nur eine Entität gefunden wurde,rowDatawird eine zurückgegeben, die alle Felder einer Entität enthält.Anmerkung
Im Gegensatz zu SQL, wo Sie nur Skalarwerte zurückgeben können, können Sie ein Objekt (als JSON) mit PartiQL zurückgeben.
Jeder Knoten enthält alle Felder auf Entitätsebene wie
entityIdarnundcomponentsFelder auf Komponentenebene wie und sowie Felder auf EigenschaftsebenepropertieswiecomponentTypeIdundcomponentName, alles als verschachteltes JSON.propertyNamepropertyValue -
Ruft alle Beziehungen mit einem Filter ab:
SELECT relationship FROM EntityGraph MATCH (e1)-[relationship]->(e2) WHERE relationship.relationshipName = 'isLocationOf'Diese Abfrage gibt alle Beziehungen in einem Arbeitsbereich mit dem Beziehungsnamen zurück
isLocationOf.Die
MATCHKlausel: gibt ein Muster an, das zwei Knoten (gekennzeichnet durch()) entspricht, die durch eine gerichtete Kante (gekennzeichnet durch-[]->) miteinander verbunden und an eine Variable gebunden sind, die aufgerufen wirdrelationship.Die
WHEREKlausel: gibt einen Filter für dasrelationshipNameFeld der Kante an, in dem sich der Wert befindetisLocationOf.Die
SELECTKlausel: gibt die Beziehungsvariable an, sodass der gesamte Kantenknoten zurückgegeben wird.Antwort
{ "columnDescriptions": [{ "name": "relationship", "type": "EDGE" }], "rows": [{ "rowData": [{ "relationshipName": "isLocationOf", "sourceEntityId": "floor_83faea7a-ea3b-56b7-8e22-562f0cf90c5a", "targetEntityId": "building_4ec7f9e9-e67e-543f-9d1b- 235df7e3f6a8", "sourceComponentName": "FloorComponent", "sourceComponentTypeId": "com.example.query.construction.floor" }] }, ... //rest of the rows are omitted ] }Der Typ der Spalte in
columnDescriptionsist einEDGE.Jedes
rowDatasteht für eine Kante mit Feldern wierelationshipName. Dies entspricht dem Namen der Beziehungseigenschaft, der für die Entität definiert ist. DiesourceEntityId,sourceComponentNameundsourceComponentTypeIdgeben Auskunft darüber, für welche Entität und Komponente die Beziehungseigenschaft definiert wurde. DastargetEntityIdgibt an, auf welche Entität diese Beziehung zeigt. -
Ruft alle Entitäten mit einer bestimmten Beziehung zu einer bestimmten Entität ab
SELECT e2.entityName FROM EntityGraph MATCH (e1)-[r]->(e2) WHERE relationship.relationshipName = 'isLocationOf' AND e1.entityName = 'room_0'Diese Abfrage gibt alle Entitätsnamen aller Entitäten zurück, die eine
isLocationOfBeziehung zu derroom_0Entität haben.Die
MATCHKlausel: gibt ein Muster an, das zwei beliebigen Knoten (e1,e2) entspricht, die eine gerichtete Kante (r) haben.Die
WHEREKlausel: gibt einen Filter für den Beziehungsnamen und den Namen der Quellentität an.Die
SELECTKlausel: gibt dasentityNameFeld ime2Knoten zurück.Antwort
{ "columnDescriptions": [ { "name": "entityName", "type": "VALUE" } ], "rows": [ { "rowData": [ "floor_0" ] } ] }In den ColumnDescriptions ist der Typ der Spalte,
VALUEda es sich um eineentityNameZeichenfolge handelt.Eine Entität,
floor_0, wird zurückgegeben.
-
- SPIEL
-
Die folgenden Muster werden in einer
MATCHKlausel unterstützt:-
Entspricht dem Knoten 'b', der auf den Knoten 'a' zeigt:
FROM EntityGraph MATCH (a)-[rel]-(b) -
Ordnet Knoten 'a' zu, der auf Knoten 'b' zeigt:
FROM EntityGraph MATCH (a)-[]->(b)Es gibt keine Variable, die an eine Beziehung gebunden ist, vorausgesetzt, dass für die Beziehung kein Filter angegeben werden muss.
-
Ordnen Sie Knoten 'a', der auf Knoten 'b' zeigt, und Knoten 'b', der auf Knoten 'a' zeigt, zu:
FROM EntityGraph MATCH (a)-[rel]-(b)Dadurch werden zwei Treffer zurückgegeben: eine von 'a' nach 'b' und eine weitere von 'b' nach 'a', daher wird empfohlen, wo immer möglich gerichtete Kanten zu verwenden.
-
Der Beziehungsname ist auch eine Bezeichnung für das Eigenschaftsdiagramm
EntityGraph, sodass Sie den Beziehungsnamen einfach hinter einem Doppelpunkt (:) angeben können, anstattrel.relationshipNamein derWHEREKlausel einen Filter für anzugeben.FROM EntityGraph MATCH (a)-[:isLocationOf]-(b) -
Verkettung: Muster können so verkettet werden, dass sie in mehreren Beziehungen übereinstimmen.
FROM EntityGraph MATCH (a)-[rel1]->(b)-[rel2]-(c) -
Variable Hop-Muster können sich auch über mehrere Knoten und Kanten erstrecken:
FROM EntityGraph MATCH (a)-[]->{1,5}(b)Diese Abfrage entspricht jedem Muster mit ausgehenden Kanten von Knoten 'a' innerhalb von 1 bis 5 Hops. Die zulässigen Quantifizierer sind:
{m,n}- zwischen m und n Wiederholungen{m,}- m oder mehr Wiederholungen.
-
- VON:
-
Ein Entitätsknoten kann verschachtelte Daten enthalten, z. B. Komponenten, die wiederum weitere verschachtelte Daten wie Eigenschaften enthalten. Auf diese kann zugegriffen werden, indem das Ergebnis des MATCH-Musters unverschachtelt wird.
SELECT e FROM EntityGraph MATCH (e), e.components AS c, c.properties AS p WHERE c.componentTypeId = 'com.example.query.construction.room', AND p.propertyName = 'roomFunction' AND p.propertyValue = 'meeting'Greifen Sie auf verschachtelte Felder zu, indem Sie Punkte in eine Variable einfügen.
.Ein Komma (,) wird verwendet, um Entitäten mit den darin enthaltenen Komponenten und dann den Eigenschaften innerhalb dieser Komponenten zu trennen (oder zu verbinden).ASwird verwendet, um eine Variable an die nicht verschachtelten Variablen zu binden, sodass sie in den OR-Klauseln verwendet werden können.WHERESELECTDiese Abfrage gibt alle Entitäten zurück, die eine mit einem Wert benannte Eigenschaftmeetingin einer KomponenteroomFunctionmit der Komponententyp-ID enthaltencom.example.query.construction.roomUm auf mehrere verschachtelte Felder eines Felds zuzugreifen, z. B. auf mehrere Komponenten in einer Entität, verwenden Sie die Komma-Notation, um eine Verknüpfung durchzuführen.
SELECT e FROM EntityGraph MATCH (e), e.components AS c1, e.components AS c2 - WÄHLEN SIE AUS:
-
-
Einen Knoten zurückgeben:
SELECT e FROM EntityGraph MATCH (e) -
Gibt eine Kante zurück:
SELECT r FROM EntityGraph MATCH (e1)-[r]->(e2) -
Gibt einen Skalarwert zurück:
SELECT floor.entityName, room.description, p.propertyValue AS roomfunction FROM EntityGraph MATCH (floor)-[:isLocationOf]-(room), room.components AS c, c.properties AS pFormatieren Sie den Namen des Ausgabefeldes, indem Sie ihn mit einem Alias versehen.
ASHier wird stattpropertyValueals Spaltenname in der Antwortroomfunctionzurückgegeben. -
Aliase zurückgeben:
SELECT floor.entityName AS floorName, luminaire.entityName as luminaireName FROM EntityGraph MATCH (floor)-[:isLocationOf]-(room)-[:hasPart]- (lightingZone)-[:feed]-(luminaire) WHERE floor.entityName = 'floor_0' AND luminaire.entityName like 'lumin%'Es wird dringend empfohlen, Aliase zu verwenden, um explizit zu sein, die Lesbarkeit zu erhöhen und Mehrdeutigkeiten in Ihren Abfragen zu vermeiden.
-
- WO:
-
Die unterstützten logischen Operatoren sind
ANDNOT, undOR.Die unterstützten Vergleichsoperatoren sind
<<=,>,=>,=, und!=.Verwenden Sie das
INSchlüsselwort, wenn Sie mehrereORBedingungen für dasselbe Feld angeben möchten.-
Filtern Sie nach einem Entitäts-, Komponenten- oder Eigenschaftsfeld:
FROM EntityGraph MATCH (e), e.components AS c, c.properties AS p WHERE e.entityName = 'room_0' AND c.componentTypeId = 'com.example.query.construction.room', AND p.propertyName = 'roomFunction' AND NOT p.propertyValue = 'meeting' OR p.propertyValue = 'office' -
Filtern Sie nach der
configurationEigenschaft. Hierunitist der Schlüssel in der Konfigurationsübersicht und derCelsiusWert.WHERE p.definition.configuration.unit = 'Celsius' -
Prüfen Sie, ob eine Karteneigenschaft einen bestimmten Schlüssel und Wert enthält:
WHERE p.propertyValue.length = 20.0 -
Prüft, ob eine Karteneigenschaft einen bestimmten Schlüssel enthält:
WHERE NOT p.propertyValue.length IS MISSING -
Prüft, ob eine Listeneigenschaft einen bestimmten Wert enthält:
WHERE 10.0 IN p.propertyValue -
Verwenden Sie die
lower()Funktion für Vergleiche ohne Berücksichtigung der Groß- und Kleinschreibung. Standardmäßig wird bei allen Vergleichen zwischen Groß- und Kleinschreibung unterschieden.WHERE lower(p.propertyValue) = 'meeting'
- WIE:
-
Nützlich, wenn Sie den genauen Wert für ein Feld nicht kennen und eine Volltextsuche für das angegebene Feld durchführen können.
%steht für Null oder mehr.WHERE e.entityName LIKE '%room%'-
Infix-Suche:
%room% -
Präfix-Suche:
room% -
Suffix-Suche:
%room -
Wenn Sie '%' in Ihren Werten haben, fügen Sie ein Escape-Zeichen ein
LIKEund geben Sie das Escape-Zeichen mitESCAPEan.
WHERE e.entityName LIKE 'room\%' ESCAPE '\' -
- UNVERWECHSELBAR:
-
SELECT DISTINCT c.componentTypeId FROM EntityGraph MATCH (e), e.components AS c-
Das
DISTINCTSchlüsselwort entfernt Duplikate aus dem Endergebnis.DISTINCTwird bei komplexen Datentypen nicht unterstützt.
-
- ZÄHLEN
-
SELECT COUNT(e), COUNT(c.componentTypeId) FROM EntityGraph MATCH (e), e.components AS cDas
COUNTSchlüsselwort berechnet die Anzahl der Elemente in einem Abfrageergebnis.COUNTwird für verschachtelte komplexe Felder und Felder mit Grafikmustern nicht unterstützt.COUNTAggregation wird beiDISTINCTverschachtelten Abfragen nicht unterstützt.Beispielsweise wird
COUNT(DISTINCT e.entityId)nicht unterstützt.
- PFAD
-
Die folgenden Musterprojektionen werden bei Abfragen mithilfe der Pfadprojektion unterstützt:
Abfragen mit variablem Hop
SELECT p FROM EntityGraph MATCH p = (a)-[]->{1, 3}(b)Bei dieser Abfrage werden Knoten-Metadaten beliebiger Muster mit ausgehenden Kanten von Knoten A innerhalb von 1 bis 3 Hops abgeglichen und projiziert.
Hop-Abfragen wurden behoben
SELECT p FROM EntityGraph MATCH p = (a)-[]->(b)<-[]-(c)Diese Abfrage gleicht Metadaten von Entitäten und eingehenden Kanten ab und projiziert sie auf b.
Ungerichtete Abfragen
SELECT p FROM EntityGraph MATCH p = (a)-[]-(b)-[]-(c)Diese Abfrage vergleicht und projiziert die Metadaten von Knoten in 1-Hop-Mustern, die a und c über b verbinden.
{ "columnDescriptions": [ { "name": "path", "type": "PATH" } ], "rows": [ { "rowData": [ { "path": [ { "entityId": "a", "entityName": "a" }, { "relationshipName": "a-to-b-relation", "sourceEntityId": "a", "targetEntityId": "b" }, { "entityId": "b", "entityName": "b" } ] } ] }, { "rowData": [ { "path": [ { "entityId": "b", "entityName": "b" }, { "relationshipName": "b-to-c-relation", "sourceEntityId": "b", "targetEntityId": "c" }, { "entityId": "c", "entityName": "c" } ] } ] } ] }Diese
PATHAbfrageantwort besteht nur aus Metadaten, die alle Knoten und Kanten der einzelnen Knoten path/pattern zwischen a und c über b identifizieren.
- LIMIT und OFFSET:
-
SELECT e.entityName FROM EntityGraph MATCH (e) WHERE e.entityName LIKE 'room_%' LIMIT 10 OFFSET 5LIMITgibt die Anzahl der Ergebnisse an, die in der Abfrage zurückgegeben werden sollen, undOFFSETgibt die Anzahl der zu überspringenden Ergebnisse an. - LIMIT und MaxResults:
-
Das folgende Beispiel zeigt eine Abfrage, die insgesamt 500 Ergebnisse zurückgibt, aber nur 50 gleichzeitig pro API-Aufruf anzeigt. Dieses Muster kann verwendet werden, wenn Sie die Anzahl der angezeigten Ergebnisse einschränken müssen, z. B. wenn Sie nur 50 Ergebnisse in einer Benutzeroberfläche anzeigen können.
aws iottwinmaker execute-query \ --workspace-id exampleWorkspace \ --query-statement "SELECT e FROM EntityGraph MATCH (e) LIMIT 500"\ --max-results 50-
Das
LIMITSchlüsselwort wirkt sich auf die Abfrage aus und begrenzt die resultierenden Zeilen. Wenn Sie die Anzahl der pro API-Aufruf zurückgegebenen Ergebnisse kontrollieren möchten, ohne die Gesamtzahl der zurückgegebenen Ergebnisse zu begrenzen, verwenden SieLIMIT. -
max-resultsist ein optionaler Parameter für die ExecuteQuery API-Aktion.max-resultsgilt nur für die API und dafür, wie Ergebnisse im Rahmen der obigen Abfrage gelesen werden.Durch die Verwendung
max-resultsin einer Abfrage können Sie die Anzahl der angezeigten Ergebnisse reduzieren, ohne die tatsächliche Anzahl der zurückgegebenen Ergebnisse zu begrenzen.
Die folgende Abfrage durchläuft die nächste Ergebnisseite. Diese Abfrage verwendet den
ExecuteQueryAPI-Aufruf, um die Zeilen 51-100 zurückzugeben, wobei die nächste Ergebnisseite durch das angegeben wirdnext-token— in diesem Fall lautet das Token:."H7kyGmvK376L"aws iottwinmaker execute-query \ --workspace-id exampleWorkspace \ --query-statement "SELECT e FROM EntityGraph MATCH (e) LIMIT 500"\ --max-results 50 --next-token "H7kyGmvK376L"-
Die
next-tokenZeichenfolge gibt die nächste Ergebnisseite an. Weitere Informationen finden Sie in der ExecuteQueryAPI-Aktion.
-
AWS IoT TwinMaker Die Knowledge-Graph-Abfrage hat die folgenden Beschränkungen:
| Name des Grenzwerts | Kontingent | Einstellbar |
|---|---|---|
|
Zeitüberschreitung für die Abfrageausführung |
10 Sekunden | Nein |
|
Maximale Anzahl von Hops |
10 | Ja |
|
Maximale Anzahl von Self |
20 | Ja |
|
Maximale Anzahl projizierter Felder |
20 | Ja |
|
Maximale Anzahl bedingter Ausdrücke ( |
10 | Ja |
|
Maximale Länge eines |
20 | Ja |
Maximale Anzahl von Elementen, die in einer Klausel angegeben werden können IN |
10 | Ja |
Maximalwert für OFFSET |
3000 | Ja |
|
Maximalwert für |
3000 | Ja |
|
Höchstwert für Traversierungen (+) |
3000 | Ja |