您的 webhook 目前會在 accountBalanceCheck
函式中使用硬式編碼資料。在本教學課程的這個步驟中,您將建立 Spanner 資料庫,並在其中填入餘額資料,然後更新函式以查詢資料庫。
專案設定
請務必將 Dialogflow 服務專員和資料庫放在同一個專案中。這是讓函式安全存取資料庫最簡單的方式。此外,您必須啟用 Spanner API。
建立資料庫前,請先從 Google Cloud 控制台選取專案。
為專案啟用 Spanner API。
可建立 Spanner 執行個體
首次使用 Spanner 時,您必須建立執行個體,這是 Spanner 資料庫會使用的資源分配單位。
前往 Google Cloud 控制台的「Spanner Instances」(Spanner 執行個體) 頁面。
點選「建立執行個體」。
在執行個體名稱一欄輸入「Tutorial Instance」。
系統會根據執行個體名稱自動輸入執行個體 ID。
在「選擇設定」中,保留預設的「區域」選項,並選取建立函式時選擇的區域位置。
在「分配運算能力」中,輸入 100 個處理單元。這可為教學課程提供最少的容量。
點選「建立」。 Google Cloud 控制台會顯示您建立的執行個體的「總覽」頁面。
可建立 Spanner 資料庫
有了執行個體後,您需要建立資料庫。如要建立資料庫,請按照下列步驟操作:
- 在執行個體「總覽」頁面中,按一下「建立資料庫」。
- 在資料庫名稱一欄輸入 tutorial-database。
- 選取 Google 標準 SQL 資料庫方言。
- 點選「建立」。 Google Cloud 控制台會顯示您建立的資料庫的「總覽」頁面。
為資料庫建立資料表
資料庫建立完成後,您需要為資料庫建立資料表。如要建立資料表,請按照下列步驟操作:
- 在資料庫「總覽」頁面的「Tables」(資料表) 部分,按一下「Create table」(建立資料表)。
在「Write DDL statements」頁面中輸入:
CREATE TABLE Checking ( AccountId INT64, Balance INT64, ) PRIMARY KEY(AccountId);
按一下「提交」。 Google Cloud 控制台會返回資料庫「總覽」頁面,並顯示正在進行結構定義更新。等待更新完成。
在資料庫「總覽」頁面的「Tables」(資料表) 部分,按一下「Create table」(建立資料表)。
在「Write DDL statements」頁面中輸入:
CREATE TABLE Savings ( AccountId INT64, Balance INT64, ) PRIMARY KEY(AccountId);
按一下「提交」。 Google Cloud 控制台會返回資料庫「總覽」頁面,並顯示正在進行結構定義更新。等待更新完成。
將資料插入資料表
資料庫已包含資料表,因此您需要在資料表中新增資料。如要新增資料,請按照下列步驟操作:
- 在資料庫「總覽」頁面的資料表清單中,按一下「Checking」資料表。 Google Cloud 控制台會顯示資料表的「Schema」頁面。
- 在左側導覽選單中,按一下「資料」,即可顯示資料表的「資料」頁面。
按一下「插入」。 Google Cloud 控制台會顯示資料表的「查詢」頁面,其中包含含有
INSERT
和SELECT
陳述式的新查詢分頁。請使用下列內容覆寫這些陳述式:INSERT INTO Checking (AccountId, Balance) VALUES(1, 1000), (2, 2000);
按一下「執行」。
在左側導覽選單中,再次按一下「資料」,即可顯示資料表的資料。確認表格是否包含所需資料。
按一下「tutorial-database: Overview」連結,即可返回資料庫總覽頁面。
在資料庫「總覽」頁面的資料表清單中,按一下「儲蓄」表格。 Google Cloud 控制台會顯示資料表的「Schema」頁面。
在左側導覽選單中,按一下「資料」,即可顯示資料表的「資料」頁面。
按一下「插入」。 Google Cloud 控制台會顯示資料表的「查詢」頁面,其中包含含有
INSERT
和SELECT
陳述式的新查詢分頁。請使用下列內容覆寫這些陳述式:INSERT INTO Savings (AccountId, Balance) VALUES(1, 10000), (2, 20000);
按一下「執行」。
在左側導覽選單中,再次按一下「資料」,即可顯示資料表的資料。確認表格是否包含所需資料。
更新 Cloud 函式以查詢資料庫
webhook 程式碼中的 accountBalanceCheck
函式會檢查是否已設定特定環境變數,以便連線至資料庫。如果未設定這些環境變數,函式會使用硬式編碼的帳戶餘額。
資料庫設定完成後,請更新 Cloud 函式,設定必要的環境變數:
開啟 Cloud Functions 總覽頁面。
按一下 tutorial-banking-webhook 函式,前往其詳細資料頁面。
按一下 [編輯]。
開啟「執行階段、建構作業和連線設定」部分。
選取「Runtime」分頁標籤。
在「Runtime environment variables」(執行階段環境變數) 部分新增下列變數:
PROJECT_ID
:您的專案 IDSPANNER_INSTANCE_ID
:您的 Spanner 執行個體 ID (可能是tutorial-instance
)SPANNER_DATABASE_ID
:您的 Spanner 資料庫 ID (可能是tutorial-database
)
點按「Next」。
按一下 [Deploy] (部署)。
等待狀態指標顯示函式已成功部署。
測試服務專員
服務專員現已準備就緒,可以開始試用。按一下 Dialogflow 主控台的「Test Agent」按鈕,開啟模擬器。請嘗試與代理人進行以下對話:
對話輪次 | 您 | 虛擬服務專員 |
---|---|---|
1 | 您好 | 您好,感謝您選擇 ACME Bank。 |
2 | 我想知道我的帳戶餘額 | 你想查看哪個帳戶的餘額:儲蓄帳戶或支票帳戶? |
3 | 檢查中 | 以下是你的最新餘額:$10.00 |
查看程式碼後,您會發現 $10 並非硬式編碼值。這表示 webhook 已成功連結至資料庫,且資料庫的餘額為 $10 美元。
疑難排解
Webhook 程式碼包含記錄陳述式。如果遇到問題,請嘗試查看 Cloud Functions 的記錄。
如果函式無法連線至資料庫,且您在記錄中看到權限錯誤,可能需要修正函式所使用的預設服務帳戶的角色。這個服務帳戶的格式為 PROJECT_ID@appspot.gserviceaccount.com
。您可以透過下列任一方式修正這個問題:
如果 IAM 主頁面顯示預設服務帳戶,請變更服務帳戶的權限。編輯者角色可行,但在實際工作環境中,您可能需要更精細的角色。
如果 IAM 主頁面未顯示預設服務帳戶,請將服務帳戶新增為新的實體,授予必要的角色。
或者,您也可以使用自己建立的服務帳戶。
更多資訊
如要進一步瞭解上述步驟,請參閱:
- 透過 Cloud Functions 使用 Cloud Spanner
- 使用 Google Cloud 控制台建立及查詢資料庫
- Google 標準 SQL 資料定義語言
- Google 標準 SQL 資料操縱語言