Bemærk
Adgang til denne side kræver godkendelse. Du kan prøve at logge på eller ændre mapper.
Adgang til denne side kræver godkendelse. Du kan prøve at ændre mapper.
Notat
Denne funktion er i øjeblikket tilgængelig som offentlig prøveversion. Denne prøveversion leveres uden en serviceniveauaftale og anbefales ikke til produktionsarbejdsbelastninger. Visse funktioner understøttes muligvis ikke eller kan have begrænsede funktioner. Du kan få flere oplysninger under Supplemental Vilkår for anvendelse af Microsoft Azure prøveversioner.
Denne artikel indeholder en omfattende reference til GQL-værdier og værdityper i graph i Microsoft Fabric.
GQL-sproget understøtter forskellige typer værdier, f.eks. tal, strenge og grafelementer. Disse værdier er organiseret i sæt, der kaldes værdityper, som definerer, hvilke handlinger du kan udføre, og hvordan værdier fungerer i forskellige kontekster. Det er vigtigt at forstå typesystemet for at skrive korrekte forespørgsler og undgå kørselsfejl.
Vigtige oplysninger
Denne artikel bruger udelukkende datasættet for eksempelgrafer på sociale netværk.
Nøglebegreber:
- Værdityper kan være null ellermateriale (kan ikke være null), afhængigt af om de inkluderer eller udelader null-værdien.
-
Værdityper, der ikke kan være null , angives syntaktisk som
NOT NULL. - Den samme værdi kan tilhøre flere værdityper (polymorfi).
- Null-værdien er medlem af alle værdityper, der kan være null.
Notat
Alle værdityper kan som standard være null, medmindre du eksplicit deklarerer dem som NOT NULL.
Angiver f.eks. heltalstypen, INT der kan være null, mens INT NOT NULL angiver materiale heltalstypen.
Sådan organiseres værdityper
Alle værdityper falder i to overordnede kategorier, der tjener forskellige formål i dine forespørgsler:
- Foruddefinerede værdityper – indbygget i sproget, f.eks. tal, strenge og booleske værdier.
- Konstruerede værdityper – sammensat af andre typer, f.eks. lister og stier.
Foruddefinerede værdityper er yderligere organiseret i specialiserede kategorier:
- Booleske værdityper – Sande, falske og ukendte værdier for logiske handlinger.
- Tegnstrengværdityper – Tekstdata med Understøttelse af Unicode.
- Numeriske værdityper – heltal og tal med flydende tal.
- Tidsbestemte værdityper – Dato- og klokkeslætsværdier med understøttelse af tidszone.
- Referenceværdityper – Referencer til noder og kanter i grafen.
- Immaterial value types – Særlige værdier som null og ingenting.
Sådan fungerer lighed og sammenligning
At forstå, hvordan GQL sammenligner værdier, er afgørende for at skrive effektive forespørgsler, især når det drejer sig om filtrering, sortering og joinforbindelser.
Grundlæggende sammenligningsregler
- Du kan generelt sammenligne værdier af samme type.
- Du kan sammenligne alle tal med hinanden, f.eks. heltal med flydende værdier.
- Du kan kun sammenligne referenceværdier, der refererer til den samme type objekt, f.eks. nodereferencer med nodereferencer og kantreferencer med kantreferencer.
Null-håndtering i sammenligninger
Når du sammenligner en værdi med null, er resultatet altid UNKNOWN. Null-håndtering følger tre værdibaserede logikprincipper. Sætningen ORDER BY behandler dog som den mindste værdi, når der sorteres NULL , hvilket giver forudsigelig funktionsmåde for sortering.
Distinktitet i forhold til lighed
Visse udsagn tester ikke for lighed, men tester snarere for distinktitet. Det er vigtigt at forstå forskellen for handlinger som og DISTINCTGROUP BY.
Distinctness-test følger de samme regler som lighed med én afgørende undtagelse: NULL adskiller sig ikke fra NULL. Distinktitet adskiller sig fra lighedstest, der involverer NULL, hvilket altid resulterer i UNKNOWN.
I følgende sætninger bruges distinctness-test:
-
RETURN DISTINCT: Bestemmer, om to rækker er dubletter af hinanden. -
GROUP BY: Bestemmer, om to rækker tilhører den samme grupperingsnøgle under sammenlægning.
To rækker fra en tabel er forskellige, hvis der er mindst én kolonne, hvor værdierne fra begge rækker er forskellige.
Booleske værdityper
Booleske værdier bruger logik med tre værdier: TRUE, FALSEog UNKNOWN.
Notat
UNKNOWN og null-værdien er den samme.
UNKNOWN er blot en null-værdi af typen BOOL.
Sådan fungerer lighed:
| Venstre værdi | Højre værdi | Result |
|---|---|---|
| SANDT | FALSK | FALSK |
| SANDT | SANDT | SANDT |
| SANDT | UKENDT | UKENDT |
| FALSK | FALSK | SANDT |
| FALSK | SANDT | FALSK |
| FALSK | UKENDT | UKENDT |
| UKENDT | FALSK | UKENDT |
| UKENDT | SANDT | UKENDT |
| UKENDT | UKENDT | UKENDT |
Sådan fungerer sammenligning:
FALSE er mindre end TRUE. Alle sammenligninger, der involverer UNKNOWN , resulterer i UNKNOWN.
Sådan skriver du booleske konstanter:
TRUEFALSE-
UNKNOWNellerNULL
Typesyntaks:
BOOL [ NOT NULL ]
Værdityper for tegnstrenge
Tegnstrenge er sekvenser af Unicode-kodepunkter (de kan være længden nul). Den tomme tegnstreng er ikke identisk med null-værdien.
Sådan fungerer sammenligning:
Tegnstrenge sammenlignes ved at sammenligne Unicode-skalarværdierne for deres kodepunkter. Denne sammenligningsmetode kaldes nogle gange sorteringen UCS_BASIC .
Sådan skriver du strengkonstanter:
Omslut tegnene med enten dobbelte anførselstegn (") eller enkelte anførselstegn ('):
"Hello, World!"
'Guten Tag!'
Du kan ikke angive bestemte Unicode-kontroltegn direkte i strengkonstanttegn. Det er specifikt ikke tilladt at bruge alle tegn fra Unicode General Category-klasserne "Cc" og "Cn". Brug i stedet C-style \-escapes:
| Input | Ikke-syndebuket tegn |
|---|---|
\\ |
\ |
\" |
" |
\' |
' |
\` |
` |
\t |
U+0009 |
\b |
U+0008 |
\n |
U+000A |
\r |
U+000D |
\f |
U+000C |
\uabcd |
U+ABCD |
\UABCDEF01 |
U+ABCDEF01 |
GQL understøtter også escaping i SQL-stil ved at fordoble omgivelserne og " tegnene':
| Faktisk streng | C-type | SQL-stil |
|---|---|---|
| Hvor "ironisk!" | "How \"ironic!\"" |
"How ""ironic!""" |
| Hvor ironisk! | 'How \'ironic!\'' |
'How ''ironic!''' |
Tips
Deaktiver C-style \-escapes ved at præfikse strengkonstanten med @.
Typesyntaks:
STRING [ NOT NULL ]
Numeriske typer
Nøjagtige numeriske typer
Graph understøtter nøjagtige tal, der er negative eller positive heltal.
Sådan fungerer sammenligning:
Systemet sammenligner alle tal med deres numeriske værdi.
Sådan skriver du heltalskonstanter:
| Beskrivelse | Eksempel | Værdi |
|---|---|---|
| Heltal | 123456 | 123456 |
| Heltal med gruppering | 123_456 | 123456 |
| Eksplicit positivt heltal | +123456 | 123456 |
| Nul | 0 | 0 |
| Negativt heltal | -123456 | -123456 |
Typesyntaks:
INT [ NOT NULL ]
INT64 [ NOT NULL ]
UINT [ NOT NULL ]
UINT64 [ NOT NULL ]
INT og INT64 angive den samme numeriske type.
Så gør UINT og UINT64.
Omtrentlige numeriske typer
Graph understøtter omtrentlige tal, der er IEEE (Institute of Electrical and Electronics Engineers) 754-kompatible flydende tal.
Sådan fungerer sammenligning:
Systemet sammenligner alle tal med deres numeriske værdi.
Sådan skriver du konstanter med flydende tal:
| Beskrivelse | Eksempel | Værdi |
|---|---|---|
| Fælles notation | 123.456 | 123.456 |
| Fælles notation med gruppering | 123_456.789 | 123456.789 |
| Videnskabelig notation | 1.23456e2 | 123.456 |
| Videnskabelig notation (stort) | 1.23456E2 | 123.456 |
| Flydende tal med suffiks | 123.456f | 123.456 |
| Dobbelt præcision med suffiks | 123.456d | 123.456 |
Yderligere numeriske overvejelser:
- Overløb og underløb: Heltalshandlinger, der overskrider det understøttede interval, kan medføre kørselsfejl eller ombrydningsfunktion, afhængigt af implementeringen.
- Præcision: Flydende talhandlinger kan miste præcision på grund af begrænsninger for repræsentation i IEEE 754.
-
Særlige flydende værdier:
NaN(Ikke et tal), positiv uendelighed (+∞) og negativ uendelighed (-∞) understøttes muligvis i kontekster med flydende tal.
Typesyntaks:
FLOAT [ NOT NULL ]
DOUBLE [ NOT NULL ]
FLOAT64 [ NOT NULL ]
DOUBLE, FLOATog FLOAT64 alle angiver den samme type.
Tidsmæssige værdityper
Zoned datetime-værdier
En zoned datetime-værdi repræsenterer en ISO 8601-kompatibel datetime med en tidszoneforskydning.
Sådan fungerer sammenligning:
Systemet sammenligner zoneopdelte datetime-værdier kronologisk med deres absolutte klokkeslætspunkter.
Sådan skriver du datetime-konstanter:
Brug ISO 8601-formatet sammen med tidszoneoplysninger.
ZONED_DATETIME('2024-08-15T14:30:00+02:00')
ZONED_DATETIME('2024-08-15T12:30:00Z')
ZONED_DATETIME('2024-12-31T23:59:59.999-08:00')
Typesyntaks:
ZONED DATETIME [ NOT NULL ]
Referenceværdityper
Referenceværdier indeholder referencer til matchende noder eller kanter.
Nodereferenceværdier
Nodereferenceværdier repræsenterer referencer til bestemte noder i din graf. Du får typisk disse værdier, når noder matches i grafmønstre. Du kan bruge disse værdier til at få adgang til nodeegenskaber og udføre sammenligninger.
Sådan fungerer sammenligning:
Sammenlign kun nodereferenceværdier for lighed. To nodereferenceværdier er ens, hvis og kun hvis de refererer til den samme node.
Graph definerer en deterministisk rækkefølge over referenceværdier. Denne rækkefølge kan dog ændres fra forespørgsel til forespørgsel, og du bør ikke stole på den i produktionsforespørgsler.
Sådan får du adgang til egenskaber:
Brug punktnotation til at få adgang til nodeegenskaber:
node_var.property_name
Abstrakte nodetyper i grafskemaer:
Når du arbejder med graftyper, skal du definere abstrakte nodetyper, der fungerer som basistyper for nedarvning, men som ikke kan instantieres direkte. Abstrakte typer muliggør polymorfe forespørgselsmønstre:
-- Abstract base type (cannot be instantiated)
ABSTRACT
(:Person => {
id :: INT64,
name :: STRING,
birth_date :: ZONED DATETIME
}),
-- Concrete types that inherit from abstract base
(:Employee => Person {
employee_id :: STRING,
department :: STRING,
hire_date :: ZONED DATETIME
})
(:Customer => :Person {
customer_id :: STRING,
membership_level :: STRING,
registration_date :: ZONED DATETIME
})
Polymorfe forespørgsler med abstrakte typer:
Abstrakte typer muliggør effektive forespørgselsmønstre, hvor du matcher med basistypen for at finde alle forekomster af afledte typer:
-- Find all Person instances (both Employee and Customer)
MATCH (p:Person)
RETURN p.name, p.birthday, labels(p) AS label_names
-- Mixed type patterns
MATCH (e:Employee)-[:knows]-(c:Customer)
WHERE e.department = 'Sales' AND c.membership_level = 'Premium'
RETURN e.name AS sales_person, c.name AS customer
Notat
De foregående forespørgsler forudsætter den graftype, der er skitseret tidligere, og bruger ikke datasættet med eksemplet på det sociale netværk.
Denne fremgangsmåde giver typesikkerhed og muliggør fleksibel, nedarvningsbaseret datamodellering i dine grafskemaer.
Typesyntaks:
NODE [ NOT NULL ]
Referenceværdier for grafkant
Referenceværdier for grafkant repræsenterer referencer til bestemte kanter i grafen. Du får typisk disse værdier, når kanter matches i grafmønstre. Du kan bruge disse værdier til at få adgang til kantegenskaber og udføre sammenligninger.
Sådan fungerer sammenligning:
Du kan kun sammenligne kantreferenceværdier for lighed. To kantreferenceværdier er kun ens, hvis de refererer til den samme kant.
Sådan får du adgang til egenskaber:
Brug punktnotation til at få adgang til kantegenskaber:
edge_var.property_name
Typesyntaks:
EDGE [ NOT NULL ]
Typer af immateriel værdi
Immaterielle værdityper indeholder ikke "almindelige" materialeværdier.
Null-værdier
Null-værdien repræsenterer fraværet af en kendt materialeværdi. Det er medlem af alle værdityper, der kan være null, og adskiller sig fra enhver materialeværdi. Det er den eneste værdi af null-typen.
Sådan fungerer sammenligning:
Når du sammenligner en værdi med null, er UNKNOWNresultatet .
Sådan skriver du null-konstanter:
NULL -- type NULL
UNKNOWN -- type BOOL
Typesyntaks:
NULL
Intet type
Intet-typen er en værditype, der ikke indeholder nogen værdier.
Selvom det kan se ud som en teknikalitet, kan du bruge intet-typen til at tildele en præcis type til værdier som tomme listeværdier. Intet-typen giver dig mulighed for at overføre tomme lister, uanset hvor en listeværditype forventes (uanset den påkrævede listeelementtype).
Typesyntaks:
NOTHING
NULL NOT NULL
(NOTHING og NULL NOT NULL angive den samme type)
Konstruerede værdityper
Vis værdier
Listeværdier er sekvenser af elementer. Lister kan indeholde elementer af samme type og kan indeholde null-værdier.
Vigtige oplysninger
Lister i grafen kan i øjeblikket ikke indeholde elementer af blandede typer.
Sådan fungerer sammenligning:
Lister sammenlignes først efter størrelse og derefter element efter element i rækkefølge. To lister er ens, hvis de har samme størrelse, og alle tilsvarende elementer er ens.
Tips
Sammenligninger, der involverer null-elementværdier, resulterer altid i UNKNOWN. Null-sammenligninger kan give overraskende resultater, når listeværdier sammenlignes.
Gruppelister:
Gruppelister er lister, der er bundet af matchende kantmønstre med variabel længde. Graph sporer deres status som gruppelister.
Du kan bruge gruppelister i vandret aggregering. Du kan få flere oplysninger under GQL-udtryk og -funktioner.
Sådan skriver du listekonstanter:
Brug kantet parentesnotation til at oprette lister:
[1, 2, 3, 4]
['hello', 'world']
[1, 'mixed', TRUE, NULL]
[] -- empty list
Sådan får du adgang til elementer:
Brug kantede parenteser med nulbaseret indeksering til at få adgang til listeelementer:
list_var[0] -- first element
list_var[1] -- second element
Almindelige listehandlinger:
-- Check if list contains a value
WHERE 'Engineering' IN employee.departments
-- List concatenation
RETURN [1, 2] || [3, 4] -- [1, 2, 3, 4]
-- List size
size(list_var)
Typesyntaks:
LIST<element_type> [ NOT NULL ]
LIST<element_type NOT NULL> [ NOT NULL ]
Hvor element_type kan være en hvilken som helst understøttet type, f.eks. STRING, INT64, DOUBLE, BOOL og meget mere.
Stiværdier
Stiværdier repræsenterer stier, der svarer til i grafen. En stiværdi indeholder en ikke-mpty sekvens af skiftende node- og kantreferenceværdier, der altid starter og slutter med en nodereferenceværdi. Disse referenceværdier identificerer noderne og kanterne af den oprindeligt tilsvarende sti i grafen.
Sådan struktureres stier:
En sti består af:
- En sekvens af noder og kanter:
node₁ - edge₁ - node₂ - edge₂ - ... - nodeₙ - Starter og slutter altid med en node.
- Indeholder mindst én node (den mindste stilængde er nul kanter).
Notat
Konstantsyntaks for stier understøttes ikke i øjeblikket.
MATCH pathVar=...path pattern... Brug i stedet til at binde stier.
Sådan fungerer sammenligning:
Du sammenligner stier ved at sammenligne lister med referenceværdier med alle deres komponentnoder og kanter i den rækkefølge, de forekommer langs stien.
Du kan få flere oplysninger i sammenligningsreglerne for listeværdier og referenceværdier.
Typesyntaks:
PATH [ NOT NULL ]
Typekonverteringer og casting
GQL understøtter både implicitte og eksplicitte typekonverteringer for at muliggøre fleksible handlinger, samtidig med at typesikkerheden bevares.
Implicitte konverteringer
Visse værdityper kan konverteres implicit, når konverteringen er sikker og ikke mister oplysninger:
- Numerisk udvidelse: Heltalsværdier kan implicit konverteres til flydende taltyper, når de bruges i blandede aritmetiske handlinger.
- Strengkontekster: Værdier kan implicit konverteres til strenge i visse kontekster, f.eks. sammenkædningshandlinger.
Eksplicit casting
Brug funktionen CAST til eksplicit at konvertere værdier mellem kompatible typer:
CAST(value AS target_type)
Eksempler:
CAST(123 AS STRING) -- "123"
CAST('456' AS INT64) -- 456
CAST(3.14 AS STRING) -- "3.14"
CAST('true' AS BOOL) -- TRUE
Regler for casting:
- Til STRING: Du kan konvertere de fleste værdityper til STRING ved hjælp af deres konstantrepræsentation.
- Til numeriske typer: Du kan konvertere strenge, der indeholder gyldige numeriske konstanter, til relevante numeriske typer.
- Til BOOL: Du kan konvertere strengene 'true' eller 'false' (forskel på store og små bogstaver) til booleske værdier.
- Ugyldige casts: Hvis du forsøger at caste inkompatible værdier, opstår der kørselsfejl.