パラメータ化されたクエリの記述
SQL ステートメントでセルを参照することで、動的スプレッドシートを作成できます。本製品 は、ステートメントをパラメータ化されたクエリとして実行します。シート内の値を変更すると、本製品 は新しいクエリを実行します。
検索可能なスプレッドシートの作成
パラメータ化されたSELECT WHERE クエリを使用して、セルを編集するときにデータを動的にフィルタするスプレッドシートを作成します。次のフィルタ検索条件は@InputSheet!A2 パラメータ(InputSheet シートのセルA2)を参照します。
SELECT ShipName, ShipCity FROM "alloydb"."schema01".Orders WHERE ShipCountry = @InputSheet!A2
任意パラメータと必須パラメータの定義
パラメータに@@ を付ける場合、参照セルの空の値はクエリに影響しません(すなわち、空の値のセルが参照されるコンディションは削除されます)。
次のクエリでは、ShipCity はオプションの検索パラメータですが、ShipCountry が指定される必要があります。
SELECT * FROM "alloydb"."schema01".Orders WHERE ShipCountry = @InputSheet!A2 AND ShipCity = @@InputSheet!A3
動的なテーブル参照
セル参照の前に@@@を付けることで、クエリ内のテーブルを動的に参照できます。次のクエリは、InputSheet シートのセルA1 から値を読み取り、リクエストを実行する際にテーブル名に使用します。
SELECT * FROM @@@InputSheet!A1
その他の検索条件の記述
デフォルトでは、AlloyDB カラムがセル値を持つ場合には、本製品 は一致を報告します。例えば、参照されたセルの値が'USA' である場合、同等のSQL 述語は:
LIKE '%USA%'
セル値に'%' を追加することで、start-with およびends-with 検索を実行することができます。
InputSheet!A2 Cell | Query | Equivalent Predicate |
'USA' | SELECT * FROM "alloydb"."schema01".Orders WHERE ShipCountry LIKE @InputSheet!A2 | LIKE '%USA%' |
'%USA' | SELECT * FROM "alloydb"."schema01".Orders WHERE ShipCountry LIKE @InputSheet!A2 | LIKE '%USA' |
'USA%' | SELECT * FROM "alloydb"."schema01".Orders WHERE ShipCountry LIKE @InputSheet!A2 | LIKE 'USA%' |