關於使用者事件

本頁說明 Gemini Enterprise 應用程式的使用者事件,包括使用者事件類型、需求和使用者事件類型範例。

如果您在自己的應用程式中使用 Gemini Enterprise API,請務必在應用程式中設定搜尋功能,取得使用者事件,然後將使用者事件資料新增至 Gemini Enterprise 應用程式。

如果您透過Google Cloud 控制台建立應用程式,則不需要手動匯入使用者事件 (也不需要閱讀本頁內容)。

如需記錄使用者事件的說明,請參閱記錄即時使用者事件。如要大量匯入過去的使用者事件,請參閱「匯入歷來的使用者事件」。

使用者事件類型

使用者瀏覽或搜尋網站時,您可以記錄下列類型的使用者事件:

使用者事件名稱 使用者操作
view-item 查看文件詳細資料。
search 在 Gemini Enterprise 應用程式中搜尋資料。

如要瞭解使用者事件物件的詳細資料,請參閱 UserEvent API 參考說明文件

使用者事件類型範例和結構定義

本節提供 Gemini Enterprise 應用程式支援的各事件類型資料格式。 我們提供 JavaScript Pixel 的範例,如果是 BigQuery,系統會提供每種型別的完整資料表結構定義。

所有使用者事件類型都可選擇是否要提供 userId

如要進一步瞭解使用者事件物件,請參閱 UserEvent API 參考說明文件

view-item

以下顯示 view-item 使用者事件資料格式。

所需檢視項目物件下限

下列範例只會顯示 view-item 使用者事件格式的必要欄位。

在大多數情況下,documents 包含相關聯文件的詳細資料。

JavaScript 像素

var user_event = {
  "eventType": "view-item",
  "userPseudoId": "user-pseudo-id",
  "eventTime": "2020-01-01T03:33:33.000001Z",
  "documents": [{
    "id": "document-id"
  }]
};

BigQuery

這是這個使用者事件類型的完整 JSON 結構定義。在 BigQuery 中為這類使用者事件建立資料表時,請指定這個結構定義。

必要欄位的模式會設為 REQUIREDREPEATED。選用欄位的模式會設為 NULLABLE

請注意,使用 BigQuery 匯入事件時,必須有 eventTimeeventTime 是時間戳記格式的字串。

[
  {
    "name": "eventType",
    "type": "STRING",
    "mode": "REQUIRED"
  },
  {
    "name": "userPseudoId",
    "type": "STRING",
    "mode": "REQUIRED"
  },
  {
    "name": "eventTime",
    "type": "STRING",
    "mode": "REQUIRED"
  },
  {
    "name": "userInfo",
    "type": "RECORD",
    "mode": "NULLABLE",
    "fields": [
      {
        "name": "userId",
        "type": "STRING",
        "mode": "NULLABLE"
      },
      {
        "name": "userAgent",
        "type": "STRING",
        "mode": "NULLABLE"
      }
    ]
  },
  {
    "name": "pageInfo",
    "type": "RECORD",
    "mode": "NULLABLE",
    "fields": [
      {
        "name": "pageviewId",
        "type": "STRING",
        "mode": "NULLABLE"
      },
      {
        "name": "uri",
        "type": "STRING",
        "mode": "NULLABLE"
      },
      {
        "name": "referrerUri",
        "type": "STRING",
        "mode": "NULLABLE"
      }
    ]
  },
  {
    "name": "attributionToken",
    "type": "STRING",
    "mode": "NULLABLE"
  },
  {
    "name": "documents",
    "type": "RECORD",
    "mode": "REPEATED",
    "fields": [
      {
        "name": "id",
        "type": "STRING",
        "mode": "NULLABLE"
      }
    ]
  },
  {
    "name": "tagIds",
    "type": "STRING",
    "mode": "REPEATED"
  },
  {
    "name": "attributes",
    "type": "RECORD",
    "mode": "NULLABLE",
    "fields": [
      {
        "name": "example_text_attribute",
        "type": "RECORD",
        "mode": "NULLABLE",
        "fields": [
          {
            "name": "text",
            "type": "STRING",
            "mode": "REPEATED"
          }
        ]
      },
      {
        "name": "example_number_attribute",
        "type": "RECORD",
        "mode": "NULLABLE",
        "fields": [
          {
            "name": "numbers",
            "type": "NUMERIC",
            "mode": "REPEATED"
          }
        ]
      }
    ]
  }
]

以下顯示 search 使用者事件格式。

必要搜尋物件下限

下列範例只會顯示 search 使用者事件格式的必要欄位。

針對使用者輸入文字查詢的搜尋事件提供 searchQuery

attributionToken 會連同搜尋查詢結果一併傳回。

documents 應包含搜尋結果網頁中向使用者顯示的文件 ID 清單。

JavaScript 像素

var user_event = {
  eventType: "search",
  userPseudoId: "user-pseudo-id",
  eventTime: "2020-01-01T03:33:33.000001Z",
  searchInfo: {
    searchQuery: "search-query",
  }, 
  attributionToken: "attribution-token",
  documents: [
    {
      id: "document-id1",
    },
    {
      id: "document-id2",
    },
  ]
};

BigQuery

這是這個使用者事件類型的完整 JSON 結構定義。在 BigQuery 中為這類使用者事件建立資料表時,請指定這個結構定義。

必要欄位的模式會設為 REQUIREDREPEATED。選用欄位的模式會設為 NULLABLE

請注意,使用 BigQuery 匯入事件時,必須有 eventTimeeventTime 是時間戳記格式的字串。

[
  {
    "name": "eventType",
    "type": "STRING",
    "mode": "REQUIRED"
  },
  {
    "name": "userPseudoId",
    "type": "STRING",
    "mode": "REQUIRED"
  },
  {
    "name": "eventTime",
    "type": "STRING",
    "mode": "REQUIRED"
  },
  {
    "name": "searchInfo",
    "type": "RECORD",
    "mode": "NULLABLE",
    "fields": [
      {
        "name": "searchQuery",
        "type": "STRING",
        "mode": "NULLABLE"
      }
    ]
  },
  {
    "name": "pageInfo",
    "type": "RECORD",
    "mode": "NULLABLE",
    "fields": [
      {
        "name": "pageCategory",
        "type": "STRING",
        "mode": "NULLABLE"
      }
    ]
  },
  {
    "name": "attributionToken",
    "type": "STRING",
    "mode": "NULLABLE"
  },
  {
    "name": "documents",
    "type": "RECORD",
    "mode": "REPEATED",
    "fields": [
      {
        "name": "id",
        "type": "STRING",
        "mode": "NULLABLE"
      }
    ]
  }
]

關於使用者資訊

userPseudoId 代表不重複的使用者 ID,記錄使用者事件時必須提供這項 ID。

記錄使用者事件時,所含的使用者資訊 (UserInfo) 包含 userPseudoId 值,以及 (如適用) userId 值。userId 為選用參數,使用者登入網站時,可做為跨裝置的永久專屬 ID。記錄使用者userId後,Gemini Enterprise 應用程式就能在多部裝置上為該使用者生成更個人化的結果,例如行動裝置和網路瀏覽器。

時間戳記簡介

記錄使用者事件時,請務必加入事件發生時間的準確時間戳記。準確的時間戳記可確保事件以正確順序儲存。系統會自動記錄使用 JavaScript 像素收集的事件時間戳記。匯入事件時,您必須在 eventTime 欄位中,以 RFC 3339 指定的格式提供時間戳記。