SQLAlchemyCore-接続詞の使用

接続詞は、SQL式のWHERE句で使用される関係演算子を実装するSQLAlchemyモジュールの関数です。演算子AND、OR、NOTなどは、2つの個別の論理式を組み合わせた複合式を形成するために使用されます。SELECTステートメントでANDを使用する簡単な例は次のとおりです。

SELECT * from EMPLOYEE WHERE salary>10000 AND age>30

SQLAlchemy関数and _()、or _()、not_()は、それぞれAND、OR、NOT演算子を実装しています。

and_()関数

ANDで結合された式の接続詞を生成します。理解を深めるために、以下に例を示します。

from sqlalchemy import and_

print(
   and_(
      students.c.name == 'Ravi',
      students.c.id <3
   )
)

これは次のように変換されます-

students.name = :name_1 AND students.id < :id_1

Studentテーブルのselect()コンストラクトでand_()を使用するには、次のコード行を使用します-

stmt = select([students]).where(and_(students.c.name == 'Ravi', students.c.id <3))

次の性質のSELECTステートメントが作成されます-

SELECT students.id, 
   students.name, 
   students.lastname
FROM students
WHERE students.name = :name_1 AND students.id < :id_1

上記のSELECTクエリの出力を表示する完全なコードは次のとおりです-

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String, ForeignKey, select
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()
conn = engine.connect()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

from sqlalchemy import and_, or_
stmt = select([students]).where(and_(students.c.name == 'Ravi', students.c.id <3))
result = conn.execute(stmt)
print (result.fetchall())

次の行は、studentsテーブルに前の例で使用したデータが入力されていると想定して選択されます-

[(1, 'Ravi', 'Kapoor')]

or_()関数

ORで結合された式の結合を生成します。上記の例のstmtオブジェクトを、or_()を使用して次のオブジェクトに置き換えます。

stmt = select([students]).where(or_(students.c.name == 'Ravi', students.c.id <3))

これは、次のSELECTクエリと実質的に同等です-

SELECT students.id, 
   students.name, 
   students.lastname
FROM students
WHERE students.name = :name_1 
OR students.id < :id_1

置換を行って上記のコードを実行すると、結果は2行がOR条件になります-

[(1, 'Ravi', 'Kapoor'),
(2, 'Rajiv', 'Khanna')]

asc()関数

昇順のORDERBY句を生成します。関数は列を取り、関数をパラメーターとして適用します。

from sqlalchemy import asc
stmt = select([students]).order_by(asc(students.c.name))

このステートメントは、次のSQL式を実装します-

SELECT students.id, 
   students.name, 
   students.lastname
FROM students 
ORDER BY students.name ASC

次のコードは、studentsテーブルのすべてのレコードを名前列の昇順で一覧表示します-

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String, ForeignKey, select
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()
conn = engine.connect()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

from sqlalchemy import asc
stmt = select([students]).order_by(asc(students.c.name))
result = conn.execute(stmt)

for row in result:
   print (row)

上記のコードは次の出力を生成します-

(4, 'Abdul', 'Sattar')
(3, 'Komal', 'Bhandari')
(5, 'Priya', 'Rajhans')
(2, 'Rajiv', 'Khanna')
(1, 'Ravi', 'Kapoor')

desc()関数

同様に、desc()関数は次のように降順のORDERBY句を生成します-

from sqlalchemy import desc
stmt = select([students]).order_by(desc(students.c.lastname))

同等のSQL式は次のとおりです。

SELECT students.id, 
   students.name, 
   students.lastname
FROM students 
ORDER BY students.lastname DESC

そして、上記のコード行の出力は次のとおりです。

(4, 'Abdul', 'Sattar')
(5, 'Priya', 'Rajhans')
(2, 'Rajiv', 'Khanna')
(1, 'Ravi', 'Kapoor')
(3, 'Komal', 'Bhandari')

between()関数

BETWEEN述語節を生成します。これは通常、特定の列の値が範囲内にあるかどうかを検証するために使用されます。たとえば、次のコードは、id列が2〜4の行を選択します。

from sqlalchemy import between
stmt = select([students]).where(between(students.c.id,2,4))
print (stmt)

結果のSQL式は次のようになります-

SELECT students.id, 
   students.name, 
   students.lastname
FROM students
WHERE students.id 
BETWEEN :id_1 AND :id_2

結果は次のようになります-

(2, 'Rajiv', 'Khanna')
(3, 'Komal', 'Bhandari')
(4, 'Abdul', 'Sattar')