確定MySQL 中「SELECT * FROM table_name;」的行順序`
執行「SELECT * FROM table_name;」時不帶ORDER」 BY 子句的查詢,MySQL 不提供任何有關結果集行順序的保證。
依賴實作細節
除非使用 ORDER 明確指定BY 子句中,行順序完全取決於 MySQL RDBMS 引擎的內部實作細節。它可能會根據索引選擇、儲存佈局和引擎採用的優化技術等因素而有所不同。
實際影響
雖然行可能是有時會以其原始插入順序或物理存儲順序返回,依賴此行為是不可取的。這是因為更改為另一個 RDBMS 甚至升級到較新版本的 MySQL 可能會導致不同的行順序。
InnoDB 的異常
在實踐中,InnoDB 儲存引擎傾向於根據從查詢最佳化器使用的索引中檢索行的順序返回行。這意味著順序可能會根據所選的特定索引而有所不同。
範例
考慮使用 InnoDB的以下示範:
CREATE TABLE foo (id SERIAL PRIMARY KEY, bar CHAR(10), baz CHAR(10), KEY(bar)); INSERT INTO foo (bar, baz) VALUES ('test5', 'test5'), ('test5', 'test5'), ('test4', 'test4'), ('test4', 'test4'), ('test3', 'test3'), ('test3', 'test3'), ('test2', 'test2'), ('test2', 'test2'), ('test1', 'test1'), ('test1', 'test1');
默認,行按主鍵順序返回(聚集
select * from foo;
但是,明確使用索引可以更改順序:
select * from foo where bar between 'test2' and 'test4';
在這種情況下,順序由條形列上的二級索引決定。下的差異
使用不同的像MyISAM 這樣的儲存引擎可能會導致不同的行為。 >總之,為了確保SQL 查詢中的行順序一致,請務必使用明確ORDER BY子句。
以上是MySQL 如何決定「SELECT * FROM table_name;」查詢中的行順序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!