mysql-關聯查詢

来源:http://www.cnblogs.com/happyflyingpig/archive/2017/11/07/7797361.html
-Advertisement-
Play Games

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 驗證數字的正則表達式集 驗證數字:^[0-9]*$ 驗證n位的數字:^\d{n}$ 驗證至少n位數字:^\d{n,}$ 驗證m-n位的數字:^\d{m,n}$ 驗證零和非零開頭的數字:^(0|[1-9][0-9]*)$ 驗證有兩位小數的正實數:^[0-9]+(.[0-9]{2})?$ 驗證有1-3位 ...
  • /* * 單向鏈表 * Node 類用來表示節點 * LinkedList 類提供了插入節點、刪除節點、顯示列表元素的方法,以及其他一些輔助方法。 */ function Node(element) { this.element = element; this.next = null; }; fun... ...
  • elementUI官方案例:http://element.eleme.io/#/zh-CN/component/date-picker (1)效果圖: (2)安裝和引入 (3)到自己的組件demo.vue里使用: ...
  • 前言 在之前的html相關的介紹中,我們已經學習了使用table來佈局網站的首頁,但是使用這種方式來佈局的話有一些缺陷,所以筆者這裡就介紹一下如何使用DIV+CSS來對網站的首頁進行佈局! 一、DIV的相關介紹 Div 它是一個 html 標簽,一個塊級元素(單獨顯示一行)。它單獨使用沒有任何意義, ...
  • 轉自CSDN: ...
  • 轉自CSDN: 購物車 我的購物車 清空購物車批量刪除 name price nu... ...
  • 學習react,使用webpack構建工具 在html引入生成的bundle.js時,寫成了這樣子: 結果報錯: 為什麼呢? 這樣不就ok了嗎!!!!!!!! 答案:看不懂英文,代碼還是看得懂的~~ https://stackoverflow.com/questions/18239430/canno ...
  • 測量應用程式的方法之一是看性能。而性能的指標之一便是用戶體驗,通俗的說法就是“用戶是否需要等待更長的時間才能得到他們想要的東西”。 這個指標在不同的應用場合而有所改變。對於移動購物應用,響應時間不能超過幾秒鐘。對於員工的人力資源頁面,可能需要多花幾秒鐘的時間。 有很多關於性能如何影響用戶行為的研究: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...