啟用資料集以使用API更新設定檔

本教學課程涵蓋以「更新插入」功能啟用資料集的程式,以更新即時客戶設定檔資料。 這包括建立新資料集和設定現有資料集的步驟。

NOTE
本教學課程中說明的工作流程僅適用於批次擷取。 如需串流擷取更新插入,請參閱使用「資料準備」將部分列更新傳送至「即時客戶個人檔案」的指南

快速入門

若要參閱本教學課程,請先實際瞭解管理已啟用設定檔的資料集所牽涉到的多項Adobe Experience Platform服務。 在開始本教學課程之前,請先檢閱這些相關Platform服務的檔案:

  • Real-Time Customer Profile:根據來自多個來源的彙總資料,提供統一的即時消費者設定檔。
  • Catalog Service: RESTful API可讓您建立資料集並為Real-Time Customer Profile和Identity Service設定資料集。
  • Experience Data Model (XDM): Platform用來組織客戶體驗資料的標準化架構。
  • 批次擷取:批次擷取API可讓您將資料以批次檔案的形式擷取到Experience Platform中。

以下章節提供您需瞭解的其他資訊,才能成功呼叫Platform API。

讀取範例 API 呼叫

本教學課程提供範例API呼叫,示範如何格式化您的請求。 這些包括路徑、必要的標頭和正確格式化的請求承載。 此外,也提供 API 回應中傳回的範例 JSON。 如需檔案中所使用範例API呼叫慣例的詳細資訊,請參閱Experience Platform疑難排解指南中如何讀取範例API呼叫一節。

收集所需標頭的值

若要呼叫Platform API,您必須先完成驗證教學課程。 完成驗證教學課程會提供所有 Experience Platform API 呼叫中每個必要標頭的值,如下所示:

  • Authorization: Bearer {ACCESS_TOKEN}
  • x-api-key: {API_KEY}
  • x-gw-ims-org-id: {ORG_ID}

所有包含裝載(POST、PUT、PATCH)的要求都需要額外Content-Type標題。 必要時,此標頭的正確值會顯示在範例要求中。

Experience Platform中的所有資源都與特定的虛擬沙箱隔離。 對Platform API的所有請求都需要x-sandbox-name標頭,以指定將在其中執行操作的沙箱名稱。 如需Platform中沙箱的詳細資訊,請參閱沙箱概觀檔案

建立已啟用設定檔更新的資料集

建立新資料集時,您可以為設定檔啟用該資料集,並在建立時啟用更新功能。

NOTE
若要建立新的已啟用設定檔的資料集,您必須知道已為設定檔啟用的現有XDM結構描述的ID。 如需如何查閱或建立啟用設定檔的結構描述的相關資訊,請參閱有關使用結構描述登入API建立結構描述的教學課程

若要建立已啟用設定檔和更新的資料集,請使用對/dataSets端點的POST請求。

API格式

POST /dataSets

要求

藉由在要求內文中的tags下同時包含unifiedIdentityunifiedProfile,資料集將在建立時啟用Profile。 在unifiedProfile陣列中,新增isUpsert:true將增加資料集支援更新的能力。

curl -X POST \
  https://platform.adobe.io/data/foundation/catalog/dataSets \
  -H 'Content-Type: application/json' \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {ORG_ID}' \
  -H 'x-sandbox-name: {SANDBOX_NAME}' \
  -d '{
        "name": "Sample dataset",
        "description: "A sample dataset with a sample description.",
        "schemaRef": {
            "id": "https://ns.adobe.com/{TENANT_ID}/schemas/31670881463308a46f7d2cb09762715",
            "contentType": "application/vnd.adobe.xed-full-notext+json; version=1"
        },
        "tags": {
            "unifiedIdentity": [
                "enabled: true"
            ],
            "unifiedProfile": [
                "enabled: true",
                "isUpsert: true"
            ]
        }
      }'
屬性
說明
schemaRef.id
資料集將依據已啟用Profile的結構描述識別碼。
{TENANT_ID}
Schema Registry內的名稱空間,其中包含屬於您組織的資源。 如需詳細資訊,請參閱Schema Registry開發人員指南的TENANT_ID一節。

回應

成功的回應會顯示一個陣列,其中包含"@/dataSets/{DATASET_ID}"形式的新建立資料集識別碼。

[
    "@/dataSets/5b020a27e7040801dedbf46e"
]

設定現有的資料集 configure-an-existing-dataset

下列步驟說明如何設定已啟用設定檔的現有資料集,以進行更新(更新插入)功能。

NOTE
為了設定要更新插入的現有設定檔啟用的資料集,您必須先停用設定檔的資料集,然後隨著isUpsert標籤重新啟用它。 如果沒有為設定檔啟用現有資料集,您可以直接進入為設定檔啟用資料集並更新插入的步驟。 如果您不確定,下列步驟將說明如何檢查資料集是否已啟用。

檢查資料集是否已針對設定檔啟用

您可以使用Catalog API檢查現有的資料集,以判斷是否已啟用它以在Real-Time Customer Profile中使用。 以下呼叫會依ID擷取資料集的詳細資料。

API格式

GET /dataSets/{DATASET_ID}
參數
說明
{DATASET_ID}
您要檢查的資料集ID。

要求

curl -X GET 'https://platform.adobe.io/data/foundation/catalog/dataSets/5b020a27e7040801dedbf46e' \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {ORG_ID}' \
  -H 'x-sandbox-name: {SANDBOX_NAME}'

回應

{
    "5b020a27e7040801dedbf46e": {
        "name": "{DATASET_NAME}",
        "imsOrg": "{ORG_ID}",
        "tags": {
            "adobe/pqs/table": [
                "unifiedprofileingestiontesteventsdataset"
            ],
            "unifiedIdentity": [
                "enabled:true"
            ],
            "unifiedProfile": [
                "enabled:true"
            ]
        },
        "version": "1.0.1",
        "created": 1536536917382,
        "updated": 1539793978215,
        "createdClient": "{CLIENT_CREATED}",
        "createdUser": "{CREATED_BY}",
        "updatedUser": "{CREATED_BY}",
        "viewId": "{VIEW_ID}",
        "files": "@/dataSetFiles?dataSetId=5b020a27e7040801dedbf46e",
        "schema": "{SCHEMA}",
        "schemaRef": {
            "id": "https://ns.adobe.com/xdm/context/experienceevent",
            "contentType": "application/vnd.adobe.xed+json"
        }
    }
}

tags屬性下,您可以看到unifiedProfile以值enabled:true出現。 因此,已針對此資料集啟用Real-Time Customer Profile。

停用設定檔的資料集

若要設定已啟用設定檔的資料集以進行更新,您必須先停用unifiedProfileunifiedIdentity標籤,然後隨著isUpsert標籤重新啟用它們。 這是使用兩個PATCH要求來完成,一次為停用,另一次為重新啟用。

WARNING
在停用時擷取到資料集中的資料將不會擷取到設定檔存放區。 在為設定檔重新啟用資料之前,您應該避免將資料擷取到資料集中。

API格式

PATCH /dataSets/{DATASET_ID}
參數
說明
{DATASET_ID}
您要更新之資料集的ID。

要求

第一個PATCH要求內文包含pathunifiedProfile以及pathunifiedIdentity,為停用標籤將這兩個路徑的value設定為enabled:false

curl -X PATCH https://platform.adobe.io/data/foundation/catalog/dataSets/5b020a27e7040801dedbf46e \
  -H 'Content-Type:application/json-patch+json' \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {ORG_ID}' \
  -H 'x-sandbox-name: {SANDBOX_NAME}' \
  -d '[
        {
            "op": "replace",
            "path": "/tags/unifiedProfile",
            "value": ["enabled:false"]
        },
        {
            "op": "replace",
            "path": "/tags/unifiedIdentity",
            "value": ["enabled:false"]
        }
      ]'

回應

成功的PATCH要求會傳回HTTP狀態200 (確定)以及包含已更新資料集ID的陣列。 此ID應符合PATCH請求中傳送的ID。 unifiedProfileunifiedIdentity標籤現已停用。

[
    "@/dataSets/5b020a27e7040801dedbf46e"
]

為設定檔和更新插入啟用資料集 enable-the-dataset

現有資料集可以使用單一PATCH請求進行設定檔和屬性更新。

IMPORTANT
為設定檔啟用資料集時,請確保與資料集相關聯的結構描述也​ 已啟用 ​設定檔。 如果結構描述未啟用設定檔,資料集​ 不會 ​在Platform UI中顯示為啟用設定檔。

API格式

PATCH /dataSets/{DATASET_ID}
參數
說明
{DATASET_ID}
您要更新之資料集的ID。

要求

要求內文包含pathunifiedProfile,將value設定為包含enabledisUpsert標籤(兩者皆設定為true),以及將pathunifiedIdentity設定value,將enabled標籤設定為true

curl -X PATCH https://platform.adobe.io/data/foundation/catalog/dataSets/5b020a27e7040801dedbf46e \
  -H 'Content-Type:application/json-patch+json' \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {ORG_ID}' \
  -H 'x-sandbox-name: {SANDBOX_NAME}' \
  -d '[
        {
            "op": "add",
            "path": "/tags/unifiedProfile",
            "value": [
                "enabled:true",
                "isUpsert:true"
            ]
        },
        {
            "op": "add",
            "path": "/tags/unifiedIdentity",
            "value": [
                "enabled:true"
            ]
        }
      ]'

回應

成功的PATCH要求會傳回HTTP狀態200 (確定)以及包含已更新資料集ID的陣列。 此ID應符合PATCH請求中傳送的ID。 unifiedProfile標籤和unifiedIdentity標籤現在已啟用並設定為屬性更新。

[
    "@/dataSets/5b020a27e7040801dedbf46e"
]

後續步驟

批次擷取工作流程現在可以使用您的設定檔和已啟用更新插入的資料集,來更新設定檔資料。 若要進一步瞭解如何將資料擷取至Adobe Experience Platform,請先閱讀資料擷取概觀

recommendation-more-help
c5c02be6-79a3-4a2f-b766-136bffe8b676