データのクエリ
接続 の手順を使用して接続し、メタデータの反映 メソッドのいずれかを使用してメタデータの一部を反映させたら、セッションオブジェクトを使用してデータをクエリできます。
query メソッドを使用したデータのクエリ
マッピングクラスが用意されている場合は、セッションオブジェクトと併用してデータソースをクエリします。エンジンをセッションにバインドしたら、マッピングクラスをセッションのクエリメソッドに提供します。次に例を示します。
engine = create_engine("amazonathena:///?AWSAccessKey='a123';AWSSecretKey='s123';AWSRegion='IRELAND';Database='sampledb';S3StagingDirectory='s3://bucket/staging/';") factory = sessionmaker(bind=engine) session = factory() for instance in session.query([AwsDataCatalog].[sampledb].Customers).filter_by(CustomerId="12345"): print("Id: ", instance.Id) print("Name: ", instance.Name) print("TotalDue: ", instance.TotalDue) print("---------")
execute メソッドを使用したデータのクエリ
セッションオブジェクトは、適切なテーブルオブジェクトと一緒にexecute() メソッドを使用してクエリを実行することもできます。アクティブなセッションがあると仮定すると、以下は同様に実行可能です。[AwsDataCatalog].[sampledb].Customers_table = [AwsDataCatalog].[sampledb].Customers.metadata.tables["[AwsDataCatalog].[sampledb].Customers"] for instance in session.execute([AwsDataCatalog].[sampledb].Customers_table.select().where([AwsDataCatalog].[sampledb].Customers_table.c.CustomerId == "12345")): print("Id: ", instance.Id) print("FullName: ", instance.Name) print("City: ", instance.BillingCity) print("---------")