首頁 >資料庫 >mysql教程 >為什麼在 SQL Server 中使用「SELECT TOP 100 PERCENT」:一種必要的邪惡或無用的語法?

為什麼在 SQL Server 中使用「SELECT TOP 100 PERCENT」:一種必要的邪惡或無用的語法?

Patricia Arquette
Patricia Arquette原創
2025-01-01 13:04:11996瀏覽

Why Use `SELECT TOP 100 PERCENT` in SQL Server:  A Necessary Evil or Useless Syntax?

利用SELECT TOP 100 Percent:深入了解未使用的功能

傳統上,在視圖定義中使用SELECT TOP 100 PERCENT 來繞繞過對未使用功能的限制在這種情況下使用ORDER BY。然而,在某些程式碼庫中,此功能在動態 SQL 語句中出現得很奇怪。這種包含是否有任何理由,或者它僅僅產生與排除 TOP 100 PERCENT 相同的結果?

令人驚訝的是,SELECT TOP 100 PERCENT 確實在「中間物化」領域找到了獨特的應用。透過利用這種構造,可以快取查詢結果並優化後續執行。 Adam Machanic 的文章對這種技術進行了啟發性的探索。

雖然以這種方式使用 SELECT TOP 100 PERCENT 的做法本身並沒有問題,但它需要極其謹慎,並且只有在絕對必要時才應採用。它對特定情況和環境因素的依賴使其容易受到架構、索引結構或行計數的細微變化的影響,從而可能導致意外和不可預測的行為。

為了清楚起見,請考慮以下範例:

無效範例:

SELECT foo From MyTable WHERE ISNUMERIC (foo) = 1 AND CAST(foo AS int) > 100

無效範例:

SELECT foo
FROM
    (SELECT foo From MyTable WHERE ISNUMERIC (foo) = 1) bar
WHERE
    CAST(foo AS int) > 100

無效範例:

SELECT foo
FROM
    (SELECT TOP 100 PERCENT foo From MyTable WHERE ISNUMERIC (foo) = 1 ORDER BY foo) bar
WHERE
    CAST(foo AS int) > 100
無效範例:

SELECT TOP 2000000000 ... ORDER BY...
有效範例(SQL Server 2000和 2005):此外,SELECT TOP 100 PERCENT 將其範圍擴展到 SQL Server 2005,透過以下方式實現潛在的無限結果:

以上是為什麼在 SQL Server 中使用「SELECT TOP 100 PERCENT」:一種必要的邪惡或無用的語法?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn