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() 一括更新クエリを実行し、データベース内のこのクエリに一致する行を更新します。 |