1. ホーム
  2. python

[解決済み] SQLAlchemy で SQL ビューを作成するには?

2023-03-23 16:11:51

質問

SQLAlchemy で SQL ビューを定義する Pythonic な方法(つまり、純粋な SQL クエリではない)はあるのでしょうか?

どのように解決するのですか?

更新しました。 SQLAlchemy の使用法のレシピも参照してください。 はこちら

私の知る限り、(読み取り専用の非マテリアライズド)ビューの作成は、そのままでは サポートされていません。しかし、SQLAlchemy 0.7 でこの機能を追加するのは簡単です (私があげた例と同じように ここで ). あなたはただ コンパイラ拡張 CreateView . この拡張子を使うと、(仮に t はテーブルオブジェクトで、カラムは id )

createview = CreateView('viewname', t.select().where(t.c.id>5))
engine.execute(createview)

v = Table('viewname', metadata, autoload=True)
for r in engine.execute(v.select()):
    print r

以下は動作例です。

from sqlalchemy import Table
from sqlalchemy.ext.compiler import compiles
from sqlalchemy.sql.expression import Executable, ClauseElement

class CreateView(Executable, ClauseElement):
    def __init__(self, name, select):
        self.name = name
        self.select = select

@compiles(CreateView)
def visit_create_view(element, compiler, **kw):
    return "CREATE VIEW %s AS %s" % (
         element.name,
         compiler.process(element.select, literal_binds=True)
         )

# test data
from sqlalchemy import MetaData, Column, Integer
from sqlalchemy.engine import create_engine
engine = create_engine('sqlite://')
metadata = MetaData(engine)
t = Table('t',
          metadata,
          Column('id', Integer, primary_key=True),
          Column('number', Integer))
t.create()
engine.execute(t.insert().values(id=1, number=3))
engine.execute(t.insert().values(id=9, number=-3))

# create view
createview = CreateView('viewname', t.select().where(t.c.id>5))
engine.execute(createview)

# reflect view and print result
v = Table('viewname', metadata, autoload=True)
for r in engine.execute(v.select()):
    print r

必要であれば、方言に特化することも可能です、例えば

@compiles(CreateView, 'sqlite')
def visit_create_view(element, compiler, **kw):
    return "CREATE VIEW IF NOT EXISTS %s AS %s" % (
         element.name,
         compiler.process(element.select, literal_binds=True)
         )