簡體   English   中英

使用JDBC,Oracle 11g進行緩慢查詢

[英]slow query using JDBC, Oracle 11g

我在Oracle查詢中遇到問題; 當我以這種方式執行查詢時,有一個表DIT_NUMBERS_ASIG:

SELECT * 
FROM DIT_NUMBERS_ASIG 
WHERE number_asig = '1234567'; //Quotes

查詢將立即執行; 但是,如果我執行此查詢:

SELECT * 
FROM DIT_NUMBERS_ASIG 
WHERE number_asig = 1234567; //Without Quotes

查詢速度很慢,大約需要2分鍾。

問題是當我嘗試從Java應用程序(使用JDBC)執行此語句時:

SELECT * 
FROM DIT_NUMBERS_ASIG 
WHERE number_asig = '1234567';

查詢速度很慢,就像沒有引號一樣。

我如何執行執行但帶引號的查詢,因為就像查詢沒有引號一樣

正如您在SQLFiddle上所提到的,執行查詢時我真的看不到有什么大的不同。 我在一個表中添加了幾行,並嘗試通過傳遞如上所述的值(帶引號和不帶引號)來檢索特定的行。 我沒有任何區別。

SQL小提琴演示

可能的解決方案:

  1. 考慮將索引添加到表中。
  2. 指定列名,而不是在SELECT語句中簡單地使用*

您也可以考慮檢查Oracle Doc的SQL調整。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM