Aggregaten gebruiken using-aggregates

In dit geval wordt beschreven hoe de laatste ontvangers die aan de database zijn toegevoegd, automatisch kunnen worden geïdentificeerd.

Met behulp van het volgende proces wordt de aanmaakdatum van ontvangers in de database vergeleken met de laatst bekende datum waarop een ontvanger is gemaakt met een aggregaat. Alle ontvangers die op dezelfde dag zijn gemaakt, worden ook geselecteerd.

Om een Aanmaakdatum = max (aanmaakdatum) Als u een filter op de ontvangers typt, moet u een workflow uitvoeren om de volgende stappen uit te voeren:

  1. Haal de ontvangers van een database op met behulp van een standaardquery. Voor meer informatie over deze stap raadpleegt u Een query maken.
  2. Bereken de laatst bekende datum een ontvanger werd gecreeerd gebruikend het resultaat dat van wordt geproduceerd max (aanmaakdatum) aggregatiefunctie.
  3. Elke ontvanger aan de samenvoegingsfunctie verbinden resulteert in het zelfde schema.
  4. Ontvangers filteren met het aggregaat via het bewerkte schema.

Stap 1: Het totale resultaat berekenen step-1--calculating-the-aggregate-result

  1. Maak een query. Hier, is het doel om de laatste bekende aanmaakdatum uit alle ontvangers in het gegevensbestand te berekenen. De query bevat daarom geen filter.

  2. Selecteer Add data.

  3. Selecteer in de geopende vensters de optie Data linked to the filtering dimension dan Filtering dimension data.

  4. In de Data to add venster, voegt u een kolom toe die de maximumwaarde voor de Aanmaakdatum in de tabel met ontvangers. U kunt de uitdrukkingsredacteur gebruiken of ingaan max (@created) rechtstreeks in een veld in Expression kolom. Klik vervolgens op de knop Finish knop.

  5. Klik op Edit additional data en vervolgens op Advanced parameters…. Schakel de optie Disable automatic adding of the primary keys of the targeting dimension in.

    Met deze optie zorgt u ervoor dat niet alle ontvangers als resultaat worden weergegeven en dat gegevens die expliciet worden toegevoegd, niet worden bewaard. In dit geval verwijst het naar de laatste datum waarop een ontvanger is gemaakt.

    Laat de optie Remove duplicate rows (DISTINCT) ingeschakeld.

Stap 2: De ontvangers koppelen en het resultaat van de aggregatiefunctie step-2--linking-the-recipients-and-the-aggregation-function-result

Om de vraag te verbinden die ontvangers behandelt aan de vraag die de berekening van de samenvoegingsfunctie uitvoert, moet u schema gebruiken uitgeeft activiteit.

  1. Definieer de query voor ontvangers als een hoofdset.

  2. In de Links voegt u een nieuwe koppeling toe en voert u de volgende informatie in het venster in:

    • Selecteer het tijdelijke schema voor het aggregaat. De gegevens voor dit schema worden toegevoegd aan de leden van de hoofdset.
    • Selecteren Use a simple join om het geaggregeerde resultaat te koppelen aan elke ontvanger van de hoofdset.
    • Geef ten slotte op dat de koppeling een Type 11 simple link.

Het aggregatieresultaat is daarom gekoppeld aan elke ontvanger.

Stap 3: Ontvangers filteren met het aggregaat. step-3--filtering-recipients-using-the-aggregate-

Zodra de verbinding is gevestigd, maken het gezamenlijke resultaat en de ontvangers deel uit van het zelfde tijdelijke schema. Het is daarom mogelijk om een filter op het schema tot stand te brengen om de aanmaakdatum van ontvangers en de laatst bekende aanmaakdatum te vergelijken, die door de samenvoegingsfunctie wordt vertegenwoordigd. Dit filter wordt uitgevoerd met behulp van een splitsingsactiviteit.

  1. In de General tab, selecteert u Ontvangers als doelgerichte dimensie en Schema bewerken als het filtreren afmeting (aan filter op de binnenkomende activiteit van het overgangsschema).

  2. In de subsets tab, selecteert u Add a filtering condition on the inbound population klik vervolgens op Edit….

  3. Voeg met behulp van de expressie-editor een gelijkheidscriterium toe tussen de aanmaakdatum van de ontvangers en de aanmaakdatum die wordt berekend door het aggregaat.

    De datumtekstvelden in de database worden over het algemeen tot op de milliseconde opgeslagen. Daarom moet u deze voor de hele dag verlengen om te voorkomen dat ontvangers worden opgehaald die slechts die milliseconde hebben gemaakt.

    Om dit te doen, gebruik ToDate functie, beschikbaar in de uitdrukkingsredacteur, die data en uren in eenvoudige data omzet.

    De voor de criteria te gebruiken uitdrukkingen zijn derhalve:

    • Expression: toDate([target/@created]).
    • Value: toDate([datemax/expr####]), waarbij expr#### betrekking heeft op het aggregaat dat is opgegeven in de query voor de aggregatiefunctie.

Het resultaat van de splitsingsactiviteit heeft dus betrekking op de ontvangers die op dezelfde dag zijn gemaakt als de laatst bekende aanmaakdatum.

Vervolgens kunt u andere activiteiten toevoegen, zoals een update van een lijst of een levering om de workflow te verrijken.

recommendation-more-help
cffff7e4-091f-472e-87ca-52087599f99d