利用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中文網其他相關文章!