MySQL關聯查詢的三種寫法: SELECT * FROM film JOIN film_actor ON (film.film_id = film_actor.film_id);SELECT * FROM film JOIN film_actor USING (film_id); --當兩個要關聯 ...
MySQL關聯查詢的三種寫法:
SELECT * FROM film JOIN film_actor ON (film.film_id = film_actor.film_id);
SELECT * FROM film JOIN film_actor USING (film_id); --當兩個要關聯表的欄位名是一樣時,可以使用USING()
SELECT * FROM film, film_actor WHERE film.film_id = film_actor.film_id;
優化關聯查詢:
- 確保ON或者USING子句中的列上有索引。在創建索引的時候就要考慮到關聯順序。一般來說,除非有其他理由,否則只需要在關聯順序中的第二個表的相應列上創建索引。比如當表film和表film_actor用列film_id關聯的時候。如果優化器的關聯順序是film_actor、film 那麼就不需要在film_actor表的film_id列上加索引了。
- 確保任何的GROUP BY 和ORDER BY 中的表達式只涉及到一個表中的列,這樣MySQL才有可能使用索引來優化這個過程。
- 當升級MySQL的時候需要註意:關聯語法、運算符優先順序等其他可能會發生變化的地方。因為以前的是普遍關聯的地方可能會變成笛卡爾積,不同類型的關聯可能會生成不同的結果等。
參考:
[1]Baron Schwartz等 著,寧海元等 譯 ;《高性能MySQL》(第3版); 電子工業出版社 ,2013
[2]博客,http://www.jb51.net/article/68442.htm