我从来没有第一次让这个工作,但现在我似乎根本无法做到。
某处有一个使用数据库的连接池,因此在应用程序使用数据库时尝试删除数据库应该会出现此错误。问题是当我发出这些命令时没有与数据库的连接:
db2 connect to mydatabase
db2 quiesce database immediate force connections
db2 connect reset
db2 drop database mydatabase
Run Code Online (Sandbox Code Playgroud)
这总是给:
SQL1035N The database is currently in use. SQLSTATE=57019
Run Code Online (Sandbox Code Playgroud)
运行此命令显示没有连接/应用程序
DB2 list applications
Run Code Online (Sandbox Code Playgroud)
我什至可以停用数据库,但仍然无法删除它。
db2 => deactivate database mydatabase
DB20000I The DEACTIVATE DATABASE command completed successfully.
db2 => drop database mydatabase
SQL1035N The database is currently in use. SQLSTATE=57019
db2 =>
Run Code Online (Sandbox Code Playgroud)
有人有任何线索吗?我正在以本地管理员(Windows 2008)的身份运行 cmd-windows,这也是 DB2 的管理员。connectionpool-user 在静止状态期间无法连接。
就像 Arun 的提示不起作用时的提示一样,因为远程应用程序会立即重新连接到数据库。
db2 force applications all
db2 terminate
db2set DB2COMM=
db2stop
db2start
db2 force applications all
db2 terminate
... do your stuff here ...
db2set DB2COMM=TCPIP
db2stop
db2start
Run Code Online (Sandbox Code Playgroud)
不过,不确定db2 force
和db2 terminate
是否必要。这只是我们的最佳实践。
归档时间: |
|
查看次数: |
20834 次 |
最近记录: |