首頁 資料庫 mysql教程 MySQL内部临时表策略_MySQL

MySQL内部临时表策略_MySQL

Jun 01, 2016 pm 01:41 PM
策略

bitsCN.com
MySQL内部临时表策略 通过对MySQL数据库源码的跟踪和调试,以及参考MySQL官方文档,对MySQL内部临时表使用策略进行整理,以便于更加深入的理解。使用内部临时表条件     MySQL内部临时表的使用有一定的策略,从源码中关于SQL查询是否需要内部临时表。可以总结如下:     1、DISTINCT查询,但是简单的DISTINCT查询,比如对primary key、unique key等DISTINCT查询时,查询优化器会将DISTINCT条件优化,去除DISTINCT条件,也不会创建临时表;     2、不是第一个表的字段使用ORDER BY 或者GROUP BY;      3、ORDER BY和GROUP BY使用不同的顺序;     4、用户需要缓存结果;         5、ROLLUP查询。      源码如下所示     代码地址:sql_select.cc:854,函数:JOIN::optimize(),位置:sql_select.cc:1399  /*    Check if we need to create a temporary table.    This has to be done if all tables are not already read (const tables)    and one of the following conditions holds:    - We are using DISTINCT (simple distinct's are already optimized away)    - We are using an ORDER BY or GROUP BY on fields not in the first table    - We are using different ORDER BY and GROUP BY orders    - The user wants us to buffer the result.    When the WITH ROLLUP modifier is present, we cannot skip temporary table    creation for the DISTINCT clause just because there are only const tables.  */      need_tmp= (( const_tables != tables &&               (( select_distinct || !simple_order || !simple_group) ||                ( group_list && order ) ||                test(select_options & OPTION_BUFFER_RESULT))) ||             ( rollup.state != ROLLUP:: STATE_NONE && select_distinct )); 内部临时表使用原则     但是使用了内部临时表,那么他是怎么存储的呢?原则是这样的:     1、当查询结果较小的情况下,使用heap存储引擎进行存储。也就是说在内存中存储查询结果。     2、当查询结果较大的情况下,使用myisam存储引擎进行存储。     3、当查询结果最初较小,但是不断增大的情况下,将会有从heap存储引擎转化为myisam存储引擎存储查询结果。          什么情况算是查询结果较小呢?从源码中if的几个参数可以看出:     1、有blob字段的情况;     2、使用唯一限制的情况;     3、当前表定义为大表的情况;     4、查询结果的选项为小结果集的情况;     5、查询结果的选项为强制使用myisam的情况。              源码如下所示     代码地址:sql_select.cc:10229,函数:create_tmp_table(),位置:sql_select.cc:10557  /* If result table is small; use a heap */  /* future: storage engine selection can be made dynamic? */  if ( blob_count || using_unique_constraint      || ( thd->variables .big_tables && !( select_options & SELECT_SMALL_RESULT ))      || ( select_options & TMP_TABLE_FORCE_MYISAM ))  {    share->db_plugin = ha_lock_engine(0, myisam_hton);    table->file = get_new_handler( share, &table ->mem_root,                                 share->db_type ());    if (group &&          ( param->group_parts > table-> file->max_key_parts () ||           param->group_length > table-> file->max_key_length ()))      using_unique_constraint=1;  }  else  {    share->db_plugin = ha_lock_engine(0, heap_hton);    table->file = get_new_handler( share, &table ->mem_root,                                 share->db_type ());  }        代码地址:sql_select.cc:11224,函数:create_myisam_from_heap(),位置:sql_select.cc:11287 /*    copy all old rows from heap table to MyISAM table    This is the only code that uses record[1] to read/write but this    is safe as this is a temporary MyISAM table without timestamp/autoincrement    or partitioning.  */  while (! table->file ->rnd_next( new_table.record [1]))  {    write_err= new_table .file-> ha_write_row(new_table .record[1]);    DBUG_EXECUTE_IF("raise_error" , write_err= HA_ERR_FOUND_DUPP_KEY ;);    if (write_err )      goto err ;  }官方文档相关内容     以上内容只是源码表面的问题,通过查询MySQL的官方文档,得到了更为权威的官方信息。     临时表创建的条件:     1、如果order by条件和group by的条件不一样,或者order by或group by的不是join队列中的第一个表的字段。     2、DISTINCT联合order by条件的查询。     3、如果使用了SQL_SMALL_RESULT选项,MySQL使用memory临时表,否则,查询询结果需要存储到磁盘。     临时表不使用内存表的原则:     1、表中有BLOB或TEXT类型。     2、group by或distinct条件中的字段大于512个字节。     3、如果使用了UNION或UNION ALL,任何查询列表中的字段大于512个字节。              此外,使用内存表最大为tmp_table_size和max_heap_table_size的最小值。如果超过该值,转化为myisam存储引擎存储到磁盘。
 参考资料:1、MySQL源码:MySQL-5.5.202、MySQL官方文档:http://dev.mysql.com/doc/refman/5.5/en/internal-temporary-tables.html  作者 king_wangheng bitsCN.com

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1662
14
CakePHP 教程
1418
52
Laravel 教程
1311
25
PHP教程
1261
29
C# 教程
1234
24
PHP秒殺系統中的價格策略與促銷活動設計要點 PHP秒殺系統中的價格策略與促銷活動設計要點 Sep 19, 2023 pm 02:18 PM

PHP秒殺系統中的價格策略和促銷活動設計要點在一個秒殺系統中,價格策略和促銷活動設計是非常重要的一部分。合理的價格策略和精心設計的促銷活動可以吸引用戶參與秒殺活動,提升系統的使用者體驗和獲利能力。以下將詳細介紹PHP秒殺系統中的價格策略和促銷活動設計要點,並提供具體的程式碼範例。一、價格策略設計要點決定基準價格:在秒殺系統中,基準價格是指商品正常銷售時的價格。在

exe轉php:實作功能擴充的有效策略 exe轉php:實作功能擴充的有效策略 Mar 04, 2024 pm 09:36 PM

EXE轉PHP:實現功能擴展的有效策略隨著互聯網的發展,越來越多的應用程式開始向web化遷移,以實現更大範圍的用戶訪問和更便捷的操作。在這個過程中,將原本以EXE(執行檔)方式運作的功能轉換為PHP腳本的需求也逐漸增加。本文將探討如何將EXE轉換為PHP來實現功能擴展,同時給出具體的程式碼範例。為什麼將EXE轉換為PHP跨平台性:PHP是一種跨平台的語言

Astar質押原理、收益拆解、空投項目及策略 & 操作保姆級攻略 Astar質押原理、收益拆解、空投項目及策略 & 操作保姆級攻略 Jun 25, 2024 pm 07:09 PM

目錄Astar Dapp 質押原理質押收益 拆解潛在空投項目:AlgemNeurolancheHealthreeAstar Degens DAOVeryLongSwap 質押策略 & 操作“AstarDapp質押”今年初已升級至V3版本,對質押收益規則做了不少調整。目前首個質押週期已結束,第二質押週期的「投票」子週期剛開始。若要獲得「額外獎勵」收益,需掌握此關鍵階段(預計持續至6月26日,現餘不到5天)。我將細緻拆解Astar質押收益,

MyBatis快取策略解析:一級快取與二級快取的最佳實踐 MyBatis快取策略解析:一級快取與二級快取的最佳實踐 Feb 21, 2024 pm 05:51 PM

MyBatis快取策略解析:一級快取與二級快取的最佳實踐在使用MyBatis進行開發時,我們經常需要考慮快取策略的選擇。 MyBatis中的快取主要分為一級快取和二級快取兩種。一級緩存是SqlSession層級的緩存,而二級緩存是Mapper層級的快取。在實際應用中,合理地使用這兩種快取是提高系統效能的重要手段。本文將透過具體的程式碼範例來解析MyBatis中一

CentOS7軟體的安裝步驟與策略全解析 CentOS7軟體的安裝步驟與策略全解析 Jan 04, 2024 am 09:40 AM

2010年開始正式接觸Linux,入門發行版是Ubuntu10.10,後來過渡到Ubunu11.04,這也嘗試了許多其他主流的發行版。進入實驗室之後,開始使用CentOS5,然後是CentOS6,現在進化到CentOS7。使用了四年的Linux,前三年在瞎折騰,浪費了不少時間,也得到了不少經驗與教訓。現在可能是真的老了,已經不願意折騰了,只希望配置好一個系統之後,就一直使用下去。為什麼要寫/讀這篇使用Linux尤其是CentOS會遇到一些坑,或是一些有潔癖的人不能忍的事情:官方源中的軟體

如何修改Windows 7密碼原則 如何修改Windows 7密碼原則 Dec 23, 2023 pm 10:41 PM

win7的密碼策略關係著我們的密碼格式、密碼需要的字元等,如果我們設定的密碼策略太過複雜,可能會讓我們在使用密碼時非常麻煩,但是也會讓我們的密碼更難被入侵,那麼win7如何更改密碼策略呢?下面就一起來看一下吧。 win7密碼原則變更教學1、鍵盤按下「win+r」開啟執行,輸入「gpedit.msc」2、回車確定之後進入本機群組原則編輯器。 3.根據圖示路徑找到「帳號原則」4、雙擊開啟右側的「密碼策略」5、接著就能在右邊設定這些密碼策略了。 (雙擊開啟即可編輯)6、設定完成之後我們可以看到整體的密碼策略。

如何實作MySQL中查看表格的資料的語句? 如何實作MySQL中查看表格的資料的語句? Nov 08, 2023 pm 01:40 PM

標題:MySQL中查看表格的資料的語句及具體程式碼範例MySQL是一種開源的關係型資料庫管理系統,它被廣泛應用於各種規模的應用程式。在MySQL中,檢視表格的資料是一個非常基礎的操作,以下將介紹如何透過具體的語句和程式碼範例來實現這項操作。首先,我們將介紹透過MySQL命令列工具查看表格的資料的語句及具體程式碼範例。假設我們有一個名為「employees」的表,以下是通

PHPCMS用戶名安全設定策略大揭秘 PHPCMS用戶名安全設定策略大揭秘 Mar 14, 2024 pm 12:06 PM

PHPCMS使用者名稱安全設定策略大揭密在網站開發中,使用者帳戶安全一直是開發者十分重視的一個面向。而使用者名稱的安全設定也是至關重要的,因為使用者名稱不僅僅是使用者登入的憑證,還可能暴露使用者的個人訊息,甚至造成安全隱患。本文將揭秘PHPCMS中的使用者名稱安全設定策略,並給予具體的程式碼範例供開發者參考。 1.防止常見使用者名為了提高使用者名稱的安全性,開發者應該避免使用者使用過於

See all articles