MySQL 強制操作以及order by 使用

来源:http://www.cnblogs.com/zhenghongxin/archive/2016/04/20/5412066.html
-Advertisement-
Play Games

我們以MySQL中常用的hint來進行詳細的解析,如果你是經常使用Oracle的朋友可能知道,Oracle的hincvt功能種類很多,對於優化sql語句提供了很多方法。 同樣,在MySQL里,也有類似的hint功能。下麵介紹一些常用的。 強制索引 MySQL FORCE INDEX 以上的SQL語句 ...


我們以MySQL中常用的hint來進行詳細的解析,如果你是經常使用Oracle的朋友可能知道,Oracle的hincvt功能種類很多,對於優化sql語句提供了很多方法。

同樣,在MySQL里,也有類似的hint功能。下麵介紹一些常用的。

強制索引  MySQL FORCE INDEX 

  1. SELECT * FROM TABLE1 FORCE INDEX (FIELD1) … 

以上的SQL語句只使用建立在FIELD1上的索引,而不使用其它欄位上的索引。

忽略索引 IGNORE INDEX

   註:如果在時間跨度比較長的查詢中,使用強制索引來命中,查詢效率會變得更高。

  1. SELECT * FROM TABLE1 IGNORE INDEX (FIELD1, FIELD2) … 

在上面的SQL語句中,TABLE1表中FIELD1和FIELD2上的索引不被使用。

關閉查詢緩衝 SQL_NO_CACHE

 

  1. SELECT SQL_NO_CACHE field1, field2 FROM TABLE1; 

有一些SQL語句需要實時地查詢數據,或者並不經常使用(可能一天就執行一兩次),這樣就需要把緩衝關了,不管這條SQL語句是否被執行過,伺服器都不會在緩衝區中查找,每次都會執行它。

MySQL force Index 強制索引:強制查詢緩衝 SQL_CACHE

 

  1. SELECT SQL_CALHE * FROM TABLE1; 

如果在my.ini中的query_cache_type設成2,這樣只有在使用了SQL_CACHE後,才使用查詢緩衝。

優先操作 HIGH_PRIORITY

HIGH_PRIORITY可以使用在select和insert操作中,讓MySQL知道,這個操作優先進行。

 

  1. SELECT HIGH_PRIORITY * FROM TABLE1; 

滯後操作 LOW_PRIORITY

LOW_PRIORITY可以使用在insert和update操作中,讓MySQL知道,這個操作滯後。

 

  1. update LOW_PRIORITY table1 set field1= where field1= … 

延時插入 INSERT DELAYED

 

  1. INSERT DELAYED INTO table1 set field1= … 

INSERT DELAYED INTO,是客戶端提交數據給MySQL,MySQL返回OK狀態給客戶端。而這是並不是已經將數據插入表,而是存儲在記憶體裡面等待排隊。當MySQL有空餘時,再插入。另一個重要的好處是,來自許多客戶端的插入被集中在一起,並被編寫入一個塊。這比執行許多獨立的插入要快很多。壞處是,不能返回自動遞增的ID,以及系統崩潰時,MySQL還沒有來得及插入數據的話,這些數據將會丟失。

強制連接順序 STRAIGHT_JOIN

 

  1. SELECT TABLE1.FIELD1, TABLE2.FIELD2 FROM TABLE1 STRAIGHT_JOIN TABLE2 WHERE … 

由上面的SQL語句可知,通過STRAIGHT_JOIN強迫MySQL按TABLE1、TABLE2的順序連接表。如果你認為按自己的順序比MySQL推薦的順序進行連接的效率高的話,就可以通過STRAIGHT_JOIN來確定連接順序。

MySQL force Index 強制索引:強制使用臨時表 SQL_BUFFER_RESULT

 

  1. SELECT SQL_BUFFER_RESULT * FROM TABLE1 WHERE … 

當我們查詢的結果集中的數據比較多時,可以通過SQL_BUFFER_RESULT.選項強制將結果集放到臨時表中,這樣就可以很快地釋放MySQL的表鎖(這樣其它的SQL語句就可以對這些記錄進行查詢了),並且可以長時間地為客戶端提供大記錄集。

分組使用臨時表 SQL_BIG_RESULT和SQL_SMALL_RESULT

 

  1. SELECT SQL_BUFFER_RESULT FIELD1, COUNT(*) FROM TABLE1 GROUP BY FIELD1; 

一般用於分組或DISTINCT關鍵字,這個選項通知MySQL,如果有必要,就將查詢結果放到臨時表中,甚至在臨時表中進行排序。SQL_SMALL_RESULT比起SQL_BIG_RESULT差不多,很少使用。

 

----------------------------------------------------------

explain的作用前面已經提到。

1 當你只查詢一條數據的時候,加上limit 1;

2 當你查詢固定條數數據的時候,要加上order by +欄位

 這樣游標就不會查詢全部了

例:

 

 

可以看到rows為15729009條記錄

如果加上order by id

那麼row為200,游標走完200就停止


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

-Advertisement-
Play Games
更多相關文章
  • 源文件這裡有http://pan.baidu.com/s/1pLlDm6f UITableView與UISearchController搜索及上拉載入,下拉刷新 ...
  • Swift提供了類似C語言的流程式控制制結構,包括可以多次執行任務的for和while迴圈,基於特定條件選擇執行不同代碼分支的if和switch語句,還有控制流程跳轉到其他代碼的break和continue語句。 除了C裡面傳統的 for 條件遞增迴圈,Swift 還增加了 for-in 迴圈,用來更簡 ...
  • 需求一:將字典轉換成自己需的對象,對象的屬性是字典的key值,直接使用key值獲取數據存在兩個缺點,一是key值難以記憶,二是直接使用key值Xcode不會有智能提示,很容易導致未知的錯誤。使用模型時,可以直接通過點語法將需要的數據點出,保證數據準確無誤。使用模型的優點還在於存儲、傳值都比較方便,不 ...
  • Objective C RunTime System (一、基本結構) === 寫OC也有一段時間了~之前一直在研究Objective C的RunTime,應該稱為Runtime系統,國內博客對Runtime的文章甚少,翻牆查閱文獻大量英文,書籍也翻閱甚多,因為近段時間家裡親人生病,一時很忙,文章斷 ...
  • 1.準備Linux環境 1.0 點擊VMware快捷方式,右鍵打開文件所在位置 -> 雙擊vmnetcfg.exe -> VMnet1 host-only ->修改subnet ip 設置網段:192.168.8.0 子網掩碼:255.255.255.0 -> apply -> ok 回到windo ...
  • mysqldump mysqldump -u root -d -R --add-drop-table basedata >basedata.sql -d只有表結構即列信息,無內容即行信息 · --no-data, -d Do not write any table row information ( ...
  • oracle客戶端導出dmp文件 備忘: 一直很少用導出dmp文件的,因為導出SQL已經夠用了,今天花了將近1個半小時,導出了一個13.2G的sql文件,記事本、editplus都無法打開,然後在plsql中導入,報錯(如圖)。 意味著一個半小時白費了。沒辦法只有使用exp導出了。 於是找到一個ba ...
  • GUID(Global unique identifier)全局唯一標識符,它是由網卡上的標識數字(每個網卡都有唯一的標識號)以及 CPU 時鐘的唯一數字生成的的一個 16 位元組的二進位值。 GUID 的格式為“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中每個 x ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...