SQLAlchemyORM-クエリの使用

SQLAlchemy ORMによって生成されるすべてのSELECTステートメントは、Queryオブジェクトによって構築されます。生成インターフェイスを提供するため、連続して呼び出すと、新しいQueryオブジェクトが返されます。これは、前者のコピーであり、追加の基準とオプションが関連付けられています。

クエリオブジェクトは、最初に次のようにセッションのquery()メソッドを使用して生成されます-

q = session.query(mapped class)

次のステートメントも上記のステートメントと同等です-

q = Query(mappedClass, session)

クエリオブジェクトには、オブジェクトのリストの形式で結果セットを返すall()メソッドがあります。顧客テーブルで実行した場合-

result = session.query(Customers).all()

このステートメントは、次のSQL式と実質的に同等です。

SELECT customers.id 
AS customers_id, customers.name 
AS customers_name, customers.address 
AS customers_address, customers.email 
AS customers_email
FROM customers

結果オブジェクトは、以下のようにForループを使用してトラバースし、基になる顧客テーブルのすべてのレコードを取得できます。これは、Customersテーブルのすべてのレコードを表示するための完全なコードです-

from sqlalchemy import Column, Integer, String
from sqlalchemy import create_engine
engine = create_engine('sqlite:///sales.db', echo = True)
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()

class Customers(Base):
   __tablename__ = 'customers'
   id = Column(Integer, primary_key =  True)
   name = Column(String)

   address = Column(String)
   email = Column(String)

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)
session = Session()
result = session.query(Customers).all()

for row in result:
   print ("Name: ",row.name, "Address:",row.address, "Email:",row.email)

Pythonコンソールは以下のようにレコードのリストを表示します-

Name: Ravi Kumar Address: Station Road Nanded Email: [email protected]
Name: Komal Pande Address: Koti, Hyderabad Email: [email protected]
Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]
Name: S.M.Krishna Address: Budhwar Peth, Pune Email: [email protected]

Queryオブジェクトには、次の便利なメソッドもあります-

シニア番号 方法と説明
1

add_columns()

返される結果列のリストに1つ以上の列式を追加します。

2

add_entity()

マップされたエンティティを、返される結果列のリストに追加します。

3

count()

このクエリが返す行数を返します。

4

delete()

一括削除クエリを実行します。このクエリに一致する行をデータベースから削除します。

5

distinct()

DISTINCT句をクエリに適用し、新しく生成されたクエリを返します。

6

filter()

SQL式を使用して、指定されたフィルタリング基準をこのクエリのコピーに適用します。

7

first()

このクエリの最初の結果を返します。結果に行が含まれていない場合はNoneを返します。

8

get()

指定された主キー識別子に基づいてインスタンスを返し、所有しているセッションのIDマップへの直接アクセスを提供します。

9

group_by()

1つ以上のGROUPBY基準をクエリに適用し、新しく生成されたクエリを返します

10

join()

このクエリオブジェクトの基準に対してSQLJOINを作成し、生成的に適用して、新しく生成されたクエリを返します。

11

one()

正確に1つの結果を返すか、例外を発生させます。

12

order_by()

1つ以上のORDERBY基準をクエリに適用し、新しく結果として得られたクエリを返します。

13

update()

一括更新クエリを実行し、データベース内のこのクエリに一致する行を更新します。