SQL-Daten-Management sql-data-management
Die Aktivität SQL-Daten-Management ermöglicht Ihnen das Schreiben eigener SQL-Scripts zum Erstellen und Auffüllen von Arbeitstabellen.
Voraussetzungen prerequisites
Vor der Konfiguration der Aktivität müssen folgende Voraussetzungen gegeben sein:
-
Die Aktivität ist nur für Remote-Datenquellen verfügbar. Deshalb muss das FDA-Package (Federated Data Access) auf Ihrer Instanz installiert sein. Weitere Informationen.
Weitere Informationen hierzu finden Sie je nach Campaign-Version in den folgenden Abschnitten:
-
Das ausgehende Schema muss in der Datenbank vorhanden und mit einer FDA-Datenbank verknüpft sein.
-
Für den Operator, der den Workflow ausführt, muss die ANGEBOTSAKTIVITÄT SQL-DATEN-MANAGEMENT VERWENDEN (useSqlDmActivity) richtig benannt sein. Weitere Informationen.
SQL-Daten-Management-Aktivität konfigurieren configuring-the-sql-data-management-activity
-
Spezifizieren Sie die Aktivität in Titel.
-
Wählen Sie das zu verwendende externe Konto aus und danach das mit diesem externen Konto verknüpfte Outbound-Schema.
note caution CAUTION Das Outbound-Schema ist unveränderlich und kann nicht bearbeitet werden. -
Fügen Sie das SQL-Script hinzu.
note caution CAUTION Der Codierer des SQL-Scripts ist dafür verantwortlich, dass das SQL-Script funktioniert und seine Referenzen (Feldnamen etc.) dem Outbound-Schema entsprechen. Wenn Sie einen vorhandenen SQL-Code laden möchten, wählen Sie die Option Der SQL-Code ist in einer in der Datenbank gespeicherten Entität enthalten aus. SQL-Scripts müssen im Menü Administration / Konfiguration / SQL-Scripts erstellt und gespeichert werden.
Andernfalls können Sie Ihr SQL-Script auch in den dafür vorgesehenen Bereich kopieren.
Mithilfe der Aktivität können Sie die folgenden Variablen im Script verwenden:
-
activity.tableName: SQL-Name der ausgehenden Arbeitstabelle.
-
task.incomingTransitionByName(‘name’).tableName: SQL-Name der Arbeitstabelle der zu verwendenden eingehenden Transition (die Transition wird durch den Namen identifiziert).
note note NOTE Der Wert ('name') entspricht dem Feld Name in den Transition-Eigenschaften.
-
-
Wenn das SQL-Script bereits Befehle zum Erstellen einer ausgehenden Arbeitstabelle enthält, deselektieren Sie die Option Arbeitstabelle automatisch erstellen. Andernfalls wird automatisch eine Arbeitstabelle erstellt, wenn der Workflow ausgeführt wird.
-
Wählen Sie Ok aus, um die Konfiguration der Aktivität zu bestätigen.
Die Aktivität ist jetzt konfiguriert und kann im Workflow ausgeführt werden.
Muster für SQL-Scripts sql-script-samples
Mit diesem Script können Sie eine Arbeitstabelle erstellen und Daten darin einfügen.
CREATE UNLOGGED TABLE <%= activity.tableName %> (
iRecipientId INTEGER DEFAULT 0,
sFirstName VARCHAR(100),
sMiddleName VARCHAR(100),
sLastName VARCHAR(100),
sEmail VARCHAR(100)
);
INSERT INTO <%= activity.tableName %>
SELECT iRecipientId, sFirstName, sMiddleName, sLastName, sEmail
FROM nmsRecipient
GROUP BY iRecipientId, sFirstName, sMiddleName, sLastName, sEmail;
Mit diesem Script können Sie eine CTAS-Operation ausführen (CREATE TABLE AS SELECT) und einen Arbeitstabellenindex erstellen:
CREATE TABLE <%= activity.tableName %>
AS SELECT iRecipientId, sEmail, sFirstName, sLastName, sMiddleName
FROM nmsRecipient
WHERE sEmail IS NOT NULL
GROUP BY iRecipientId, sEmail, sFirstName, sLastName, sMiddleName;
CREATE INDEX ON <%= activity.tableName %> (sEmail);
ANALYZE <%= activity.tableName %> (sEmail);
Mit diesem Script können Sie zwei Arbeitstabellen verbinden:
CREATE TABLE <%= activity.tableName %>
AS SELECT i1.sFirstName, i1.sLastName, i2.sEmail
FROM <%= task.incomingTransitionByName('input1').tableName %> i1
JOIN <%= task.incomingTransitionByName('input2').tableName %> i2 ON (i1.id = i2.id)