SQLAlchemyCore-テキストSQLの使用

SQLAlchemyを使用すると、SQLがすでにわかっていて、動的機能をサポートするステートメントが強く必要ない場合に、文字列を使用できます。text()構文は、ほとんど変更されずにデータベースに渡されるテキストステートメントを作成するために使用されます。

それは新しいを構築します TextClause、以下のコードに示すように、テキストSQL文字列を直接表します-

from sqlalchemy import text
t = text("SELECT * FROM students")
result = connection.execute(t)

利点 text() プレーンな文字列で提供するのは-

  • バインドパラメータのバックエンドニュートラルサポート
  • ステートメントごとの実行オプション
  • 結果-列の入力動作

text()関数には、名前付きコロン形式のバインドされたパラメーターが必要です。これらは、データベースのバックエンドに関係なく一貫しています。パラメータの値を送信するには、追加の引数としてそれらをexecute()メソッドに渡します。

次の例では、テキストSQLでバインドされたパラメーターを使用しています。

from sqlalchemy.sql import text
s = text("select students.name, students.lastname from students where students.name between :x and :y")
conn.execute(s, x = 'A', y = 'L').fetchall()

text()関数は次のようにSQL式を作成します-

select students.name, students.lastname from students where students.name between ? and ?

x = 'A'およびy = 'L'の値がパラメーターとして渡されます。結果は、「A」と「L」の間の名前を持つ行のリストです。

[('Komal', 'Bhandari'), ('Abdul', 'Sattar')]

text()コンストラクトは、TextClause.bindparams()メソッドを使用して事前に確立されたバインド値をサポートします。パラメータは、次のように明示的に入力することもできます。

stmt = text("SELECT * FROM students WHERE students.name BETWEEN :x AND :y")

stmt = stmt.bindparams(
   bindparam("x", type_= String), 
   bindparam("y", type_= String)
)

result = conn.execute(stmt, {"x": "A", "y": "L"})

The text() function also be produces fragments of SQL within a select() object that 
accepts text() objects as an arguments. The “geometry” of the statement is provided by 
select() construct , and the textual content by text() construct. We can build a statement 
without the need to refer to any pre-established Table metadata. 

from sqlalchemy.sql import select
s = select([text("students.name, students.lastname from students")]).where(text("students.name between :x and :y"))
conn.execute(s, x = 'A', y = 'L').fetchall()

使用することもできます and_() text()関数を使用して作成されたWHERE句で複数の条件を組み合わせる関数。

from sqlalchemy import and_
from sqlalchemy.sql import select
s = select([text("* from students")]) \
.where(
   and_(
      text("students.name between :x and :y"),
      text("students.id>2")
   )
)
conn.execute(s, x = 'A', y = 'L').fetchall()

上記のコードは、IDが2より大きい「A」と「L」の間の名前の行をフェッチします。コードの出力は次のとおりです。

[(3, 'Komal', 'Bhandari'), (4, 'Abdul', 'Sattar')]