Skapa en on-demand-mallapp
PÅ DEN HÄR SIDAN
Skapa en on-demand-mallapp
En on-demand-mallapp är en vanlig Qlik Sense-app med en viktig skillnad: dess laddningsskript innehåller databindningsuttryck som används för att formulera frågorna som ställs på datakällorna. Dessa databindningsuttryck används vid genereringen av on-demand-appen för att läsa värden i urvalsläget i urvalsappen och binda dem till skriptet i mallappen så att den genererade appen laddas med en användarstyrd delmängd av data.
Mallappen ansluter normalt sett till samma datakälla som urvalsappen. Laddningsskriptet för en urvalsapp laddar vanligtvis aggregerade data för att reducera datavolymerna samtidigt som interaktiva visualiseringar av viktiga dimensioner och mått erbjuds. Laddningsskriptet för en mallapp använder frågor som laddar en kontrollerad delmängd av mer detaljerade data.
Mallappens struktur
En mallapp är länkad till en urvalsapp med en navigeringslänk för on-demand-appen. Appnavigeringslänken innehåller egenskaper som styr antalet poster som frågas efter när on-demand-appen laddas med data. Laddningsskriptet för mallappen innehåller databindningsuttryck som anger vilka fältdata från urvalsappen som ska användas för att formulera frågor som utfärdas vid laddning av data i on-demand-appen.
Databindningsuttryck har formen:
$(od_FIELDNAME)
Prefixet od_ används för att binda urvalsläget för urvalsappen till laddningsskriptet för On-demand-appen, som skapas genom att mallappen kopieras. Den del av databindningsuttrycket som följer efter prefixet od_ måste vara ett namn som matchar ett fält i urvalsappen. När on-demand-appen genereras används det aktuella urvalsläget i urvalsappen för att hämta de önskade värdena att binda för varje fält. Varje förekomst av ett $(od_FIELDNAME)-uttryck i laddningsskriptet för den nya on-demand-appen ersätts med listan över valda värden för motsvarande fält i urvalsläget för urvalsappen.
Mer information om att binda värden med INLINE load-satser, see Bindningsuttryck i on-demand-mallappar.
För att vara giltig i
SUB ExtendWhere(Name, ValVarName) LET T = Name & '_COLNAME'; LET ColName = $(T); LET Values = $(ValVarName); IF len(Values) > 0 THEN IF len(WHERE_PART) > 0 THEN LET WHERE_PART = '$(WHERE_PART) AND $(ColName) IN ( $(Values) )'; ELSE LET WHERE_PART = ' WHERE $(ColName) IN ( $(Values) )'; ENDIF ENDIF END SUB;
Innan du anropar den underordnade rutinen
Om du vill att SQL-satsen ska ha en oförändrad WHERE-sats utöver de satser som infogas av urvalsappen, infogar du ett
Följande är ett exempel på hur den underordnade rutinen
FOR EACH fldname IN 'ORIGIN', 'DEST', 'YEAR', 'QUARTER', 'ORIGIN_STATE_ABR', 'DEST_STATE_ABR' LET vallist = $(fldname); WHEN (IsNull(vallist)) LET vallist = ''; IF len(vallist) > 0 THEN CALL ExtendWhere('$(fldname)','vallist'); ENDIF NEXT fldname
Listan över fältnamn bör matcha namnen på de fält som används i varje fältbindning du har skapat.
När du har skapat värdelistan för varje fält kan du skriva en SELECT-sats. Exempel:
SQL SELECT "MKT_ID", "YEAR", "QUARTER", "ORIGIN", "ORIGIN_STATE_ABR", "DEST", "DEST_STATE_ABR", "TICKET_CARRIER", "FARE_CLASS", "PASSENGERS", "DISTANCE", 1 AS "FLIGHT_COUNT" FROM "SAPH7T"."/QT/AIRPORT_FACT" $(WHERE_PART);
Enkel inloggning (SSO)
On-demand-appar kan använda single sign-on (SSO) med datakällor som stöder SSO. Motorn och datakällan måste konfigureras för att tillåta SSO.
Mer information finns i Konfigurera SAP HANA för SAML Single Sign-On med Qlik Sense (endast på engelska) och Konfigurera Cloudera Impala för Single Sign-On (endast på engelska).
När motorn och datakällan har konfigurerats för SSO måste du aktivera SSO i mallappen genom att lägga till följande syntax i mallappens skript:
///!ODAG_SSO
On-Demand App Service parsar skriptet när en on-demand-app genereras och varje gång den laddas igen.
När en on-demand-app laddas med SSO skickas slutanvändarens identitet till datakällan. Slutanvändaren måste ha åtkomst till källorna som används i mallappens datakopplingar. Endast data som användaren har åtkomst till i källorna laddas, även om en större datauppsättning är vald.
Ladda noder igen för mallappar
Administratörer kan kontrollera var on-demand-appar laddas igen i miljöer med flera noder genom att ställa in regler för lastbalansering på mallappar. När en lastbalanseringsregel ställs in laddas alla appar som genererats från länkar till mallappen enligt den regel som tillämpas på mallappen.