-
Notifications
You must be signed in to change notification settings - Fork 1
/
04_Create Online Tables.py
78 lines (49 loc) · 2.8 KB
/
04_Create Online Tables.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# Databricks notebook source
# MAGIC %md
# MAGIC # Create Online Tables
# COMMAND ----------
# MAGIC %md
# MAGIC ###Online Tables and Feature Serving
# MAGIC An online table is a read-only copy of a Delta Table that is stored in row-oriented format optimized for online access. Online tables are fully serverless tables that auto-scale throughput capacity with the request load and provide low latency and high throughput access to data of any scale. Online tables are designed to work with Mosaic AI Model Serving, Feature Serving, and agentic applications where they are used for fast data lookups. [Read More](https://docs.databricks.com/en/machine-learning/feature-store/online-tables.html)
# MAGIC
# MAGIC Let us now create the required Online Tables
# MAGIC
# MAGIC <img src="https://raw.githubusercontent.com/databricks-industry-solutions/CareCost-Compass/refs/heads/main/resources/build_4.png" alt="Online Tables" width="900"/>
# MAGIC
# MAGIC We will be needing online tables for our `member_enrolment`, `member_accumulatord` and `procedure_cost` table.
# COMMAND ----------
# MAGIC %run ./utils/utils
# COMMAND ----------
# MAGIC %md
# MAGIC ###### Online table for `member_enrolment`
# COMMAND ----------
create_online_table(f"{catalog}.{schema}.{member_table_name}", ["member_id"])
create_feature_serving(f"{catalog}.{schema}.{member_table_name}", ["member_id"])
# COMMAND ----------
# MAGIC %md
# MAGIC ###### Online table for `procedure_cost`
# COMMAND ----------
create_online_table(f"{catalog}.{schema}.{procedure_cost_table_name}", ["procedure_code"])
create_feature_serving(f"{catalog}.{schema}.{procedure_cost_table_name}",["procedure_code"])
# COMMAND ----------
# MAGIC %md
# MAGIC ###### Online table for `member_accumulators`
# COMMAND ----------
create_online_table(f"{catalog}.{schema}.{member_accumulators_table_name}", ["member_id"])
create_feature_serving(f"{catalog}.{schema}.{member_accumulators_table_name}", ["member_id"])
# COMMAND ----------
# MAGIC %md
# MAGIC ##NOTE Online table endpoints takes few minutes to be provisioned and available.
# MAGIC Please make sure that the endpoints are ready before proceeding further, by check the status in `Serving` page as below
# MAGIC
# MAGIC <img src="https://raw.githubusercontent.com/databricks-industry-solutions/CareCost-Compass/refs/heads/main/resources/online_endpoint.png" width="800" />
# COMMAND ----------
# MAGIC %md
# MAGIC ######Query the endpoints to test
# COMMAND ----------
get_data_from_online_table(f"{catalog}.{schema}.{member_table_name}", {"member_id":"1234"})
# COMMAND ----------
get_data_from_online_table(f"{catalog}.{schema}.{procedure_cost_table_name}", {"procedure_code":"23920"})
# COMMAND ----------
get_data_from_online_table(f"{catalog}.{schema}.{member_accumulators_table_name}", {"member_id":"1234"})
# COMMAND ----------