Kommentar
Åtkomst till den här sidan kräver auktorisering. Du kan prova att logga in eller ändra kataloger.
Åtkomst till den här sidan kräver auktorisering. Du kan prova att ändra kataloger.
Gäller för:
Databricks SQL
Databricks Runtime
Namnlösning är den process som identifierare löses till specifika kolumn-, fält-, parameter- eller tabellreferenser.
Kolumn-, fält-, parameter- och variabelupplösning
Identifierare i uttryck kan vara referenser till något av följande:
- Kolumnnamn baserat på en vy, tabell, ett vanligt tabelluttryck (CTE) eller en column_alias.
- Fältnamn eller kartnyckel i en struct eller karta. Fält och nycklar kan aldrig vara utan kvalifikationer.
- Parameternamn för en SQL-användardefinierad funktion eller SQL-procedur.
- Lokalt variabelnamn för sessions- eller SQL-skript.
- En särskild funktion som
current_userellercurrent_datesom inte kräver användning av(). - Nyckelordet
DEFAULTsom används i kontexten förINSERT,UPDATE,MERGEellerSET VARIABLEför att ange ett kolumn- eller variabelvärde till standardvärdet.
Namnuppslagning tillämpar följande principer:
- Den närmaste matchande referensen vinner och
- Kolumner och parameter vinner över fält och nycklar.
I detalj följer lösningen av identifierare till en specifik referens dessa regler i ordning:
Lokala referenser
Kolumnreferens
Matcha identifieraren, som kan vara kvalificerad, med ett kolumnnamn i en tabellreferens för
FROM clause.Om det finns fler än en sådan matchning ska ett AMBIGUOUS_COLUMN_OR_FIELD-fel visas.
Parameterlös funktionsreferens
Om identifieraren är okvalificerad och matchar
current_user,current_dateellercurrent_timestamp: Lös det som en av dessa funktioner.standardspecifikation för kolumn
Om identifieraren är okvalificerad matchar den
defaultoch utgör hela uttrycket i kontexten av enUPDATE SET,INSERT VALUESellerMERGE WHEN [NOT] MATCHED: Lös det som det respektiveDEFAULT-värdet för måltabellen iINSERT,UPDATEellerMERGE.Referens för strukturfält eller mappnyckel
Om identifieraren är kvalificerad ska du försöka matcha den med ett fält eller en kartnyckel enligt följande steg:
A. Ta bort den sista identifieraren och behandla den som ett fält eller en nyckel. B. Matcha resten med en kolumn i tabellreferens för
FROM clause.Om det finns fler än en sådan matchning ska ett AMBIGUOUS_COLUMN_OR_FIELD-fel visas.
Om det finns matchning och kolumnen är en:
STRUCT: Anpassa fältet.Om fältet inte kan matchas skapar du ett FIELD_NOT_FOUND fel.
Om det finns fler än ett fält skapar du ett AMBIGUOUS_COLUMN_OR_FIELD fel.
MAP: Generera ett fel om nyckeln är kvalificerad.Ett körningsfel kan inträffa om nyckeln inte finns på kartan.
Annan typ: Utlösa ett fel. C. Upprepa föregående steg för att ta bort den avslutande identifieraren som ett fält. Tillämpa regler (A) och (B) medan det finns en identifierare kvar att tolka som en kolumn.
Lateral kolumnalias
Gäller för:
Databricks SQL
Databricks Runtime 12.2 LTS och senareOm uttrycket finns i en
SELECT-lista, ska den inledande identifieraren matchas med ett föregående -kolumnalias i denSELECT-listan.Om det finns fler än en sådan matchning genereras ett AMBIGUOUS_LATERAL_COLUMN_ALIAS-fel.
Matcha varje återstående identifierare som ett fält eller en nyckel i en kartstruktur och utlös felet FIELD_NOT_FOUND eller AMBIGUOUS_COLUMN_OR_FIELD om de inte kan matchas.
Korrelation
LATERAL
Om frågan föregås av ett
LATERALnyckelord tillämpar du reglerna 1.a och 1.d med tanke på tabellreferenserna iFROMsom innehåller frågan och föreLATERAL.Vanligt
Om frågan är en skalär underfråga,
IN, ellerEXISTSunderfråga tillämpar du reglerna 1.a, 1.d och 2 med tanke på tabellreferenserna i den innehållande frågans satsFROM.
Kapslad korrelation
Använd regel 3 igen och iterera över frågans nästlade nivåer.
-
Om påståendet finns i en
FOR-loop:A. Matcha identifieraren med en kolumn i en
FORloop-instruktionsfråga. Om identifieraren är kvalificerad måste kvalificeraren matcha namnet på FOR-loopvariabeln om den definieras. B. Om identifieraren är kvalificerad matchar du ett fält eller en mappnyckel för en parameter enligt regel 1.c -
Om uttalandet ingår i ett sammansatt block:
A. Matcha identifieraren med en variabel som deklarerats i den sammansatta instruktionen. Om identifieraren är kvalificerad måste kvalificeraren matcha etiketten för den sammansatta instruktionen, om en sådan har definierats. B. Om identifieraren är kvalificerad, matcha en fält- eller mappnyckel hos en variabel enligt regel 1.c
kapslad sammansatt sats eller
FOR-loopTillämpa reglerna 5 och 6 igen och iterera över kapslingsnivåerna i den sammansatta satsen.
Rutinparametrar
Om uttrycket är en del av en CREATE FUNCTION eller CREATE PROCEDURE-instruktion :
- Matcha identifieraren med ett parameternamn. Om identifieraren är kvalificerad måste kvalificeraren matcha namnet på rutinen.
- Om identifieraren är kvalificerad matchar du ett fält eller en mappnyckel för en parameter enligt regel 1.c
Sessionsvariabler
- Matcha identifieraren med ett variabelnamn. Om identifieraren är kvalificerad måste kvalificeraren vara
sessionellersystem.session. - Om identifieraren är kvalificerad, matcha en fält- eller mappnyckel hos en variabel enligt regel 1.c
- Matcha identifieraren med ett variabelnamn. Om identifieraren är kvalificerad måste kvalificeraren vara
Namnmatchning i HAVING, ORDER BYoch QUALIFY
HAVINGSatserna , ORDER BYoch QUALIFY kan referera till namn från SELECT listan samt kolumner från de underliggande tabellerna. När ett namn i någon av dessa satser matchar både ett kolumnalias i SELECT listan och en tabellkolumn löser satserna tvetydigheten på ett annat sätt:
-
ORDER BYföredrar listalias framförSELECTtabellkolumnen. -
HAVINGföredrar tabellkolumnen framför listaliasetSELECT. -
QUALIFYföredrar tabellkolumnen framför listaliasetSELECT(samma somHAVING).
Exempel
> CREATE OR REPLACE TEMPORARY VIEW t(a, b) AS VALUES (1, 10), (2, 20), (3, 30);
-- ORDER BY prefers the alias over the column.
-- 'a' in ORDER BY refers to the alias (-a), not column 'a',
-- so the row with the largest column 'a' comes first.
> SELECT -a AS a FROM t ORDER BY a LIMIT 1;
-3
-- HAVING prefers the column over the alias.
-- 'a' in HAVING refers to column 'a', not the alias sum(b).
> SELECT sum(b) AS a FROM t GROUP BY a HAVING a > 1;
20
30
-- QUALIFY prefers the column over the alias (same as HAVING).
-- 'a' in QUALIFY refers to column 'a', not the alias -row_number().
> SELECT -row_number() OVER (ORDER BY b) AS a FROM t QUALIFY a > 1;
-2
-3
Prioritet för fältextrahering och namnmatchning
När ett kvalificerat namn, a.b till exempel används i HAVING eller ORDER BY, gäller fortfarande prioritetsreglerna ovan, men med ytterligare övervägande: den föredragna kandidaten måste ha stöd för extrahering av struct-fält eller kartnyckel. Om den inte gör det används den andra kandidaten i stället.
Om aliaset a till exempel matchas till en oformaterad INT men tabellkolumnen a är ett STRUCT med fält ORDER BYxväljer du STRUCT kolumnen eftersom ett fält inte kan extraheras från aliasetINT. Om tabellkolumnen däremot är oformaterad INT och aliaset är ett STRUCT, HAVING återgår du till aliaset för fältextrahering.
Exempel
-- ORDER BY fallback: the table column is a STRUCT, the alias is an INT.
-- ORDER BY normally prefers the alias, but the alias (INT) cannot have
-- field 'x' extracted, so the struct column wins.
> CREATE OR REPLACE TEMPORARY VIEW s1(a) AS VALUES (named_struct('x', 1)), (named_struct('x', 2));
> SELECT -a.x AS a FROM s1 ORDER BY a.x LIMIT 1;
-1
-- HAVING fallback: the table column is an INT, the alias is a STRUCT.
-- HAVING normally prefers the table column, but the column (INT) cannot have
-- field 'x' extracted, so the alias wins.
> CREATE OR REPLACE TEMPORARY VIEW s2(a) AS VALUES (1), (2);
> SELECT named_struct('x', 2) AS a FROM s2 GROUP BY a HAVING a.x > 1;
{"x":2}
{"x":2}
-- Map key extraction follows the same rules.
-- ORDER BY fallback: alias (INT) cannot have key extracted, map column wins.
> CREATE OR REPLACE TEMPORARY VIEW s3(a) AS VALUES (map('key', 100)), (map('key', 200));
> SELECT -a['key'] AS a FROM s3 ORDER BY a['key'] LIMIT 1;
-100
-- HAVING fallback: column (INT) cannot have key extracted, map alias wins.
> CREATE OR REPLACE TEMPORARY VIEW s4(a) AS VALUES (100), (200);
> SELECT map('key', 200) AS a FROM s4 GROUP BY a HAVING a['key'] > 100;
{"key":200}
{"key":200}
Begränsningar
För att förhindra körning av potentiellt dyra korrelerade förfrågningar begränsar Azure Databricks korrelationen till en nivå. Den här begränsningen gäller även för parameterreferenser i SQL-funktioner.
Exempel
-- Differentiating columns and fields
> SELECT a FROM VALUES(1) AS t(a);
1
> SELECT t.a FROM VALUES(1) AS t(a);
1
> SELECT t.a FROM VALUES(named_struct('a', 1)) AS t(t);
1
-- A column takes precedence over a field
> SELECT t.a FROM VALUES(named_struct('a', 1), 2) AS t(t, a);
2
-- Implict lateral column alias
> SELECT c1 AS a, a + c1 FROM VALUES(2) AS T(c1);
2 4
-- A local column reference takes precedence, over a lateral column alias
> SELECT c1 AS a, a + c1 FROM VALUES(2, 3) AS T(c1, a);
2 5
-- A scalar subquery correlation to S.c3
> SELECT (SELECT c1 FROM VALUES(1, 2) AS t(c1, c2)
WHERE t.c2 * 2 = c3)
FROM VALUES(4) AS s(c3);
1
-- A local reference takes precedence over correlation
> SELECT (SELECT c1 FROM VALUES(1, 2, 2) AS t(c1, c2, c3)
WHERE t.c2 * 2 = c3)
FROM VALUES(4) AS s(c3);
NULL
-- An explicit scalar subquery correlation to s.c3
> SELECT (SELECT c1 FROM VALUES(1, 2, 2) AS t(c1, c2, c3)
WHERE t.c2 * 2 = s.c3)
FROM VALUES(4) AS s(c3);
1
-- Correlation from an EXISTS predicate to t.c2
> SELECT c1 FROM VALUES(1, 2) AS T(c1, c2)
WHERE EXISTS(SELECT 1 FROM VALUES(2) AS S(c2)
WHERE S.c2 = T.c2);
1
-- Attempt a lateral correlation to t.c2
> SELECT c1, c2, c3
FROM VALUES(1, 2) AS t(c1, c2),
(SELECT c3 FROM VALUES(3, 4) AS s(c3, c4)
WHERE c4 = c2 * 2);
[UNRESOLVED_COLUMN] `c2`
-- Successsful usage of lateral correlation with keyword LATERAL
> SELECT c1, c2, c3
FROM VALUES(1, 2) AS t(c1, c2),
LATERAL(SELECT c3 FROM VALUES(3, 4) AS s(c3, c4)
WHERE c4 = c2 * 2);
1 2 3
-- Referencing a parameter of a SQL function
> CREATE OR REPLACE TEMPORARY FUNCTION func(a INT) RETURNS INT
RETURN (SELECT c1 FROM VALUES(1) AS T(c1) WHERE c1 = a);
> SELECT func(1), func(2);
1 NULL
-- A column takes precedence over a parameter
> CREATE OR REPLACE TEMPORARY FUNCTION func(a INT) RETURNS INT
RETURN (SELECT a FROM VALUES(1) AS T(a) WHERE t.a = a);
> SELECT func(1), func(2);
1 1
-- Qualify the parameter with the function name
> CREATE OR REPLACE TEMPORARY FUNCTION func(a INT) RETURNS INT
RETURN (SELECT a FROM VALUES(1) AS T(a) WHERE t.a = func.a);
> SELECT func(1), func(2);
1 NULL
-- Lateral alias takes precedence over correlated reference
> SELECT (SELECT c2 FROM (SELECT 1 AS c1, c1 AS c2) WHERE c2 > 5)
FROM VALUES(6) AS t(c1)
NULL
-- Lateral alias takes precedence over function parameters
> CREATE OR REPLACE TEMPORARY FUNCTION func(x INT)
RETURNS TABLE (a INT, b INT, c DOUBLE)
RETURN SELECT x + 1 AS x, x
> SELECT * FROM func(1)
2 2
-- All together now
> CREATE OR REPLACE TEMPORARY VIEW lat(a, b) AS VALUES('lat.a', 'lat.b');
> CREATE OR REPLACE TEMPORARY VIEW frm(a) AS VALUES('frm.a');
> CREATE OR REPLACE TEMPORARY FUNCTION func(a INT, b int, c int)
RETURNS TABLE
RETURN SELECT t.*
FROM lat,
LATERAL(SELECT a, b, c
FROM frm) AS t;
> VALUES func('func.a', 'func.b', 'func.c');
a b c
----- ----- ------
frm.a lat.b func.c
Tabell- och vyhantering
En identifierare i tabellreferens kan vara något av följande:
- Beständiga tabeller eller vyer i Unity-katalogen eller Hive-metaarkivet
- Gemensamt tabelluttryck (CTE)
- Tillfällig vy eller tillfällig tabell
Lösningen på en identifierare beror på om den är kvalificerad:
Kvalificerad
Om identifieraren är fullständigt kvalificerad med tre delar:
catalog.schema.relationär den unik.Om identifieraren består av två delar:
schema.relation, är den ytterligare kvalificerad med resultatet avSELECT current_catalog()för att göra den unik.Okvalificerad
gemensamt tabelluttryck
Om referensen ligger inom omfånget för en
WITH-sats matchar du identifieraren med en CTE som börjar med den omedelbart innehållandeWITH-satsen och flyttar utåt därifrån.Tillfällig vy eller tillfällig tabell
Matcha identifieraren med en temporär vy eller temporär tabell som definierats i den aktuella sessionen.
Varaktig tabell
Kvalificera identifieraren fullständigt genom att vänta på resultatet av
SELECT current_catalog()ochSELECT current_schema()och leta upp den som en beständig relation.
Om relationen inte kan matchas till någon tabell, vy eller CTE, genererar Databricks ett TABLE_OR_VIEW_NOT_FOUND fel.
Exempel
-- Setting up a scenario
> USE CATALOG spark_catalog;
> USE SCHEMA default;
> CREATE TABLE rel(c1 int);
> INSERT INTO rel VALUES(1);
-- An fully qualified reference to rel:
> SELECT c1 FROM spark_catalog.default.rel;
1
-- A partially qualified reference to rel:
> SELECT c1 FROM default.rel;
1
-- An unqualified reference to rel:
> SELECT c1 FROM rel;
1
-- Add a temporary view with a conflicting name:
> CREATE TEMPORARY VIEW rel(c1) AS VALUES(2);
-- For unqualified references the temporary view takes precedence over the persisted table:
> SELECT c1 FROM rel;
2
-- Temporary views cannot be qualified, so qualifiecation resolved to the table:
> SELECT c1 FROM default.rel;
1
-- An unqualified reference to a common table expression wins even over a temporary view:
> WITH rel(c1) AS (VALUES(3))
SELECT * FROM rel;
3
-- If CTEs are nested, the match nearest to the table reference takes precedence.
> WITH rel(c1) AS (VALUES(3))
(WITH rel(c1) AS (VALUES(4))
SELECT * FROM rel);
4
-- To resolve the table instead of the CTE, qualify it:
> WITH rel(c1) AS (VALUES(3))
(WITH rel(c1) AS (VALUES(4))
SELECT * FROM default.rel);
1
-- For a CTE to be visible it must contain the query
> SELECT * FROM (WITH cte(c1) AS (VALUES(1))
SELECT 1),
cte;
[TABLE_OR_VIEW_NOT_FOUND] The table or view `cte` cannot be found.
Funktionslösning
En funktionsreferens igenkänns av de obligatoriska avslutande parenteserna.
Det kan lösa sig till:
- En inbyggd funktion som tillhandahålls av Azure Databricks,
- En tillfällig användardefinierad funktion som är begränsad till den aktuella sessionen, eller
- En beständig användardefinierad funktion som lagras i hive-metaarkivet eller Unity-katalogen.
Lösning av ett funktionsnamn beror på om det är kvalificerat:
Kvalificerad
Om namnet är fullständigt kvalificerat med tre delar:
catalog.schema.functionär det unikt.Om namnet består av två delar:
schema.functionär det ytterligare kvalificerat med resultatet avSELECT current_catalog()för att göra det unikt.Funktionen söks sedan upp i katalogen.
Okvalificerad
För okvalificerade funktionsnamn följer Azure Databricks en fast prioritetsordning (
PATH):Inbyggd funktion
Om det finns en funktion med det här namnet bland uppsättningen inbyggda funktioner väljs den funktionen.
Tillfällig funktion
Om det finns en funktion med det här namnet bland uppsättningen med tillfälliga funktioner väljs den funktionen.
Beständiga funktioner
Fullständigt kvalificera funktionsnamnet genom att vänta på resultatet av
SELECT current_catalog()ochSELECT current_schema()och leta upp det som en beständig funktion.
Om funktionen inte kan lösas genererar Azure Databricks ett UNRESOLVED_ROUTINE fel.
Exempel
> USE CATALOG spark_catalog;
> USE SCHEMA default;
-- Create a function with the same name as a builtin
> CREATE FUNCTION concat(a STRING, b STRING) RETURNS STRING
RETURN b || a;
-- unqualified reference resolves to the builtin CONCAT
> SELECT concat('hello', 'world');
helloworld
-- Qualified reference resolves to the persistent function
> SELECT default.concat('hello', 'world');
worldhello
-- Create a persistent function
> CREATE FUNCTION func(a INT, b INT) RETURNS INT
RETURN a + b;
-- The persistent function is resolved without qualifying it
> SELECT func(4, 2);
6
-- Create a conflicting temporary function
> CREATE FUNCTION func(a INT, b INT) RETURNS INT
RETURN a / b;
-- The temporary function takes precedent
> SELECT func(4, 2);
2
-- To resolve the persistent function it now needs qualification
> SELECT spark_catalog.default.func(4, 3);
6