私は自分のプロジェクトでsqlalchemyを使用しています、dbセッションを使用しました、
engine = create_engine(configuration)
db_session = scoped_session(sessionmaker(autocommit=False,
autoflush=False,
bind=engine))
Base = declarative_base()
Base.query = db_session.query_property()
def init_db():
import models
Base.metadata.create_all(bind=engine)
使用されるDBセッション:
db_session.merge(order) #order(model) in object
db_session.commit()
次に、2つのテーブルorderとorder line itemにデータを挿入したいので、次のようにトランザクションが必要です。1.最初の挿入で、挿入された注文のIDを2番目の挿入クエリで使用します。2。2番目の挿入クエリが失敗した場合、最初のクエリはロールバックする
Try:
#begin transaction/How to begin transaction?
order=db_session.add(order) #insert into order
#is need to commit db_session here as I need inserted orders id
#here actually db_session.commit() needed to get order's id(auto generated)
#if db_session committed here then sql alchemy starts new session
order_line_item.id = order.id
db_session.add(order_line_item) #insert into order line line item
db_session.commit()
#check transaction status if failed then rollback, How to check status?
except:
db_session.rollback()
トランザクションの使い方は?