7

我正在尝试使用 sqlalchemy 删除我的数据库:

def dropDb(self, dbName):
    self.closeConnection()
    self.selectDb(None)
    self.execute("drop database %s" % dbName)

def closeConnection(self):
    self._Session.close_all()
    self._engine.dispose()
    del self._Session
    del self._engine

我使用以下方法创建引擎:

sqlalchemy.create_engine(connection_string, poolclass = NullPool)

但我收到以下错误:

详细 ProgrammingError: (ProgrammingError) ('42000', '[42000] [Microsoft][ODBC SQL Server Driver][SQL Server]Cannot drop database "test_db" because it current is in use. (3702) (SQLExecDirectW)') '删除数据库 test_db' ()

如何强制关闭所有连接?

4

1 回答 1

4

当前使用 SQLAlchemy 会话 api 关闭所有连接的方法是

from sqlalchemy.orm import close_all_sessions

close_all_sessions()

session.close_all()弃用。

于 2021-01-27T01:40:18.303 回答