注: 以下の翻訳の正確性は検証されていません。AIPを利用して英語版の原文から機械的に翻訳されたものです。
仮想テーブル を使用すると、Foundryにデータを保存せずに、サポートされているデータプラットフォームのテーブルにクエリを実行したり、書き込みを行ったりできます。
Pythonトランスフォームでは transforms-tables
ライブラリを使用してテーブルと対話できます。
Pythonトランスフォームから仮想テーブルと対話するには、以下を行う必要があります。
transforms-tables
をインストールする。Python的な仮想テーブルAPIは、仮想テーブルと対話するための TableInput
および TableOutput
タイプを提供します。
Copied!1 2 3 4 5 6 7 8 9
from transforms.api import transform from transforms.tables import TableInput, TableOutput, TableTransformInput, TableTransformOutput @transform( source_table=TableInput("ri.tables.main.table.1234"), # 入力テーブルの指定 output_table=TableOutput("ri.tables.main.table.5678"), # 出力テーブルの指定 ) def compute(source_table: TableTransformInput, output_table: TableTransformOutput): ... # 通常のtransforms APIの操作
Pythonトランスフォームで参照されるテーブルは、同じソースや同じプラットフォームから来る必要はありません。
上記の例では、トランスフォームで指定されたテーブルがすでにFoundry環境内に存在していることが前提となっています。そうでない場合、データセットの出力と同様に、チェック時に出力仮想テーブルを作成するように設定できます。これには、テーブルを保存するソースと場所を指定するための追加設定が必要です。
Copied!1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
from transforms.api import transform from transforms.tables import TableInput, TableOutput, TableTransformInput, TableTransformOutput, SnowflakeTable @transform( source_table=TableInput("ri.tables.main.table.1234"), output_table=TableOutput( "/path/to/new/table", # Must specify the Data Connection source you want to create the table in and the table identifier/location # 作成するテーブルのデータ接続ソースとテーブル識別子/場所を指定する必要があります "ri.magritte..source.1234", SnowflakeTable("database", "schema", "table"), # Snowflakeテーブルの情報を指定 ), ) def compute(source_table: TableTransformInput, output_table: TableTransformOutput): ... # 通常のtransforms API