Przykłady niestandardowego kodu SQL dla Direct Query | Qlik Cloud Pomoc
Przeskocz do zawartości głównej Przejdź do treści uzupełniającej

Przykłady niestandardowego kodu SQL dla Direct Query

Poniższe przykłady przedstawiają niektóre opcje dostępne podczas korzystania z niestandardowego kodu SQL dla Direct Query.

Przykład: Dodawanie niestandardowych definicji SQL do modelu Direct Query

W tym przykładzie niestandardowe definicje SQL dla tabel C, R, N są dodawane do modelu danych w aplikacji Direct Query wraz z dwiema relacjami między tabelami. Funkcja Coalesce służy do sprawdzania, czy wartość pola N_NATIONKEY jest równa wartości C_NATIONKEY lub czy obie są równe null.

Wskazówka

Coalesce to zalecany sposób na sprawdzenie, czy wartość pola jest równa null. Więcej informacji zawiera temat coalescefunkcja skryptu i funkcja wykresu.

LIB CONNECT TO 'CustomSQL:Snowflake_example.com'; Section DirectQuery; C: Select C_NATIONKEY, Sum(C_ACCTBAL) as C_SUM from tpch1.customer group by C_NATIONKEY; R: SELECT R_REGIONKEY, R_NAME from tpch1.region; N: SELECT N_REGIONKEY, N_NAME, N_NATIONKEY from tpch1.nation; Create Relationship Between R, N Matching R_REGIONKEY With N_REGIONKEY; Create Relationship Between Outer Joined N, Inner Joined C On (coalesce([N_NATIONKEY], -1) = coalesce([C_NATIONKEY], -1));

Przykład: Dodawanie tabel z niestandardowym kodem SQL do modelu danych utworzonego za pomocą narzędzia Menedżer modelu danych

W tym przykładzie model danych Direct Query jest najpierw tworzony z zawartością obiektu DirectQueryModel.main, który został utworzony za pomocą narzędzia Menedżer modelu danych. Następnie do modelu danych dodawana jest dodatkowa tabela C z polami C_CUSTKEY i C_ACCTBAL. Tworzona jest relacja między polem O_CUSTKEY w tabeli ORDERS a polem C_CUSTKEY w tabeli C.

LIB CONNECT TO 'CustomSQL:Snowflake_example.com'; // DMM created model portion includes Orders table. IMPORT LIVE 'ModelName@obj://DirectQueryModel.Main'; Section DirectQuery; C: Select C_CUSTKEY, C_ACCTBAL from tpch1.customer; Create Relationship Between ORDERS, C on (O_CUSTKEY = C_CUSTKEY);

Przykład: Tworzenie modelu danych Direct Query z tabelą niestandardowego kodu SQL

W tym przykładzie model danych Direct Query jest tworzony z tabelą niestandardowego kodu SQL C ze zmienionymi nazwami pól C_KEY i C_BAL. Następnie instrukcja IMPORT LIVE dodaje model danych utworzony w narzędziu Menedżer modelu danych z obiektu DirectQueryModel.main. Ten model danych zawiera tabelę Orders i ma istniejącą relację między tabelami Orders i Customer w tym modelu. Następnie istniejąca relacja między tabelami Customers i Orders zostaje usunięta i definiowana jest nowa relacja między tabelami Orders i C.

LIB CONNECT TO 'CustomSQL:Snowflake_example.com'; Section DirectQuery; C: Select C_CUSTKEY as C_KEY, C_ACCTBAL as C_BAL from tpch1.customer; // DMM created model portion includes Orders table. IMPORT LIVE 'ModelName@obj://DirectQueryModel.Main'; // This relationship was defined using DMM between ORDERS and CUSTOMER, but I want to define my own. Drop Relationship Between ORDERS, CUSTOMER; Create Relationship Between ORDERS, C on (O_CUSTKEY = C_KEY);

Przykład: Tworzenie modelu danych zawierającego zmienne

W tym przykładzie najpierw definiowana jest zmienna MULT o wartości 100. Następnie jest ona stosowana jako mnożnik do sumy PS_Supplycost w celu obliczenia pola S.

LIB CONNECT TO 'CustomSQL:Snowflake_example.com'; Section DirectQuery; LET MULT=100; T1: SELECT PS_AVAILQTY AS C, SUM(PS_SUPPLYCOST) * $(MULT) AS S FROM "TPCH.01"."PARTSUPP" GROUP BY C;

Przykład: Tworzenie modelu danych za pomocą wyrażeń Qlik

W tym przykładzie do zbudowania modelu danych użyto zarówno zmiennych, jak i wyrażeń. W tabeli ORDERS_AGGREGATIONS wyrażenia służą do definiowania wartości w ORDERS_GROUP_TOTAL_PRICE. Za każdym razem, gdy w arkuszu zostaną dokonane wybory, które miałyby wpływ na wartości w ORDERS_GROUP_TOTAL_PRICE, wyrażenie zostanie ponownie ocenione na podstawie danych zwróconych przez zapytanie do bazy danych.

IMPORT LIVE 'ModelName@obj://DirectQueryModel.Main'; section DirectQuery; let Aggr1 = 1; let Aggr2 = 0; [GROUPS]: SELECT 0 as GROUP_CODE, 'NONE' as "GROUP" UNION ALL SELECT 1 as GROUP_CODE, 'ORDERSTATUS' as "GROUP" UNION ALL SELECT 2 as GROUP_CODE, 'ORDERPRIORITY' as "GROUP" ; [ORDERS_AGGREGATIONS]: SELECT 'BY ORDERSTATUS' as "GROUP_NAME", "O_ORDERSTATUS" as "ORDERS_GROUP", sum("O_TOTALPRICE") as "ORDERS_GROUP_TOTAL_PRICE" FROM "TEST1"."TPCH.01"."ORDERS" WHERE '$(=min({<GROUP_CODE={0,1}>}[GROUP_CODE]))' = '1' GROUP BY 1,2 UNION ALL SELECT 'BY ORDERPRIORITY' as "GROUP_NAME", "O_ORDERPRIORITY" as "ORDERS_GROUP", sum("O_TOTALPRICE") as "ORDERS_GROUP_TOTAL_PRICE" FROM "TEST1"."TPCH.01"."ORDERS" WHERE '$(=min({<GROUP_CODE={0,2}>}[GROUP_CODE]))' = '2' GROUP BY 1,2; ; [ORDERS_AGGREGATIONS_VARS]: SELECT 'BY ORDERSTATUS' as "GROUP_NAME_V", "O_ORDERSTATUS" as "ORDERS_GROUP_V", sum("O_TOTALPRICE") as "ORDERS_GROUP_TOTAL_PRICE_V" FROM "TEST1"."TPCH.01"."ORDERS" WHERE $(=Aggr1) = 1 GROUP BY 1,2 UNION ALL SELECT 'BY ORDERPRIORITY' as "GROUP_NAME_V", "O_ORDERPRIORITY" as "ORDERS_GROUP_V", sum("O_TOTALPRICE") as "ORDERS_GROUP_TOTAL_PRICE_V" FROM "TEST1"."TPCH.01"."ORDERS" WHERE $(=Aggr2) = 1 GROUP BY 1,2; ;

Przykład: Używanie funkcji w niestandardowych wyrażeniach SQL

Poniższa niestandardowa instrukcja SQL demonstruje proste użycie wyrażenia silnika $(=…), które jest rozwijane podczas wykonywania w niestandardowym kodzie SQL. Wyrażenie to pobiera wiersze z odległej bazy danych w zależności od informacji o użytkowniku sesji aplikacji. Gdy wykres, zapytanie lub wybór są wykonywane przez użytkownika sesji aplikacji Direct Query o adresie e-mail 'user1@qlik.com', wówczas dynamiczne pobieranie wierszy danych z odległej bazy danych SQL jest filtrowane tak, aby pasowało tylko do wierszy, w których pole C_NAME zawiera wartość 'Customer#000000007'. W przeciwnym razie, jeśli adres e-mail użytkownika sesji aplikacji Direct Query nie brzmi 'user1@qlik.com', pobrane i pokazane zostaną tylko te wiersze, w których pole C_NAME zawiera wartość 'Customer#000000009'.

T8: SELECT * FROM mydb.tpch01.customer WHERE mydb.tpch01.customer.C_NAME = '$(=if(GetUserAttr('userEmail') = 'user1@qlik.com', 'Customer#000000007','Customer#000000009'))';

Czy ta strona była pomocna?

Jeżeli natkniesz się na problemy z tą stroną lub jej zawartością — literówkę, brakujący krok lub błąd techniczny — daj nam znać!