java - Future Cancel 是否也会终止数据库端的 Oracle 查询

标签 java completable-future

我正在使用 Java Future 类来执行连接 Oracle 数据库的程序。然而有时查询比预期慢得多。我可以通过 future.cancel 方法取消 future 。

假设我通过 future.cancel 取消了 future 的线程。查询会在 Oracle 中停止执行吗?还是只有应用程序线程会停止/取消,Oracle 查询将继续在数据库端运行。

我们正在提交许多 future,有些非常慢。超时不会结束提交,但只能为 future.get 设置,但 future 仍然按照 java 规范继续。

这种情况下的实际行为是什么。

谢谢

最佳答案

您可以尝试向数据库发送终止查询,您将在其中使用要终止的查询的 PID,尝试使用此链接以不同的方式终止查询 How to kill a running SELECT statement 。 将进程放入线程,然后尝试添加诸如 isInterrupted()isAlive() 之类的内容来检查线程的状态,然后发送查询以终止正在运行的查询如果它被终止了。 这是我能想到的终止正在运行的数据库的最佳方法 在一个程序中。

关于java - Future Cancel 是否也会终止数据库端的 Oracle 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58721983/

相关文章:

java - 如何在netbeans平台中制作 "Open File..."窗口?

java - 枚举:创建具有不同值的相同 "type"的多个枚举?

java - 为什么 CompletableFuture 在单独的流中加入/获得比使用一个流更快

java - 是否有可能在具有 Completable future 的 Java 中为 IO 密集型服务获得高吞吐量(4-5 TPS),或者 NodeJs 是更好的选择

java - CompletableFuture.allOf 已完成,即使其列表中的一个 CompletableFuture 尚未完成

java - 在 Java 8/11 中是否可以组合 2 个以上的 CompletableFuture?

java - 如何将此 XML 文件解析为 MySQL 表?

java - 是否可以使用 Java 过滤不良语言单词?

java - 生产者-消费者在单个消费者和任意数量的生产者的情况下仅使用notify()

java - 如何使用 runAsync 等待完整的 future 完全完成?