SQLAlchemy / SQLSoup 在 MySQL 中看不到临时表

wob*_*col 4 python mysql sqlalchemy temp-tables sqlsoup

我继承了 SQLQlchemy / SQLSoup 应用程序,需要将其扩展 20 倍。

一个查询运行得非常慢,所以我重构了它。由于MySQL在嵌套子查询/派生表上的性能较差,我将其分成两个临时表并将它们连接起来。

现在我尝试将 SQL 添加到代码中,但是当我尝试访问临时表时,收到一条错误消息,指出该表不存在。

db.execute("""DROP TABLE IF  EXISTS next_requests""") ;
db.execute("""
        CREATE TEMPORARY TABLE next_requests
                (INDEX request_id_index (cirId)) 
        SELECT DISTINCT 
            cr.uuid             AS cirId,
            ....")

db.execute("SELECT * FROM next_requests")
Run Code Online (Sandbox Code Playgroud)

现在我收到错误:

ProgrammingError: (ProgrammingError) (1146, "Table 'SAST.next_requests' (doesn't exist") 
Run Code Online (Sandbox Code Playgroud)

我认为这是因为会话正在关闭并在查询之间重新操作,或者类似的原因。

数据库连接如下。

ENGINE = create_engine(settings.dbString, pool_recycle=1800, pool_size=5)
SESSION = scoped_session(sessionmaker(autoflush=True,\
    expire_on_commit=False, autocommit=True))
SQLSOUP_DB = sqlsoup.SQLSoup(ENGINE, session=SESSION)
Run Code Online (Sandbox Code Playgroud)

(SQLSOUP_DB 是 db.execute 中使用的数据库)。

我需要做什么才能保持会话打开,以便我仍然可以使用临时表。或者可能是其他原因导致了这个问题?

wob*_*col 5

好吧,我必须使用会话。像这样包装 SQL 语句:

session = database.SESSION
with session.begin() : 
    database.execute("Create Temporary Table.....")
    database.execute("Create Temporary Table2.....")
Run Code Online (Sandbox Code Playgroud)