掌握MySQL如何使用临时表,避免踩中性能地雷

MySQL如何使用临时表??

【临时表存储】
MySQL临时表分为“内存临时表”和“磁盘临时表”,其中内存临时表使用MySQL的MEMORY存储引擎,磁盘临时表使用MySQL的MyISAM存储引擎;
一般情况下,MySQL会先创建内存临时表,但内存临时表超过配置指定的值后,MySQL会将内存临时表导出到磁盘临时表。

【使用临时表的场景】
1)ORDER
BY子句和GROUP BY子句不同,
例如:ORDERY
BY price GROUP BY name;

2)在JOIN查询中,ORDER
BY或者GROUP BY使用了不是第一个表的列
例如:SELECT
* from TableA, TableB ORDER BY TableA.price GROUP by TableB.name

3)ORDER
BY中使用了DISTINCT关键字
ORDERY
BY DISTINCT(price)

4)SELECT语句中指定了SQL_SMALL_RESULT关键字
SQL_SMALL_RESULT的意思就是告诉MySQL,结果会很小,请直接使用内存临时表,不需要使用索引排序
SQL_SMALL_RESULT必须和GROUP
BY、DISTINCT或DISTINCTROW一起使用
一般情况下,我们没有必要使用这个选项,让MySQL服务器选择即可。

【直接使用磁盘临时表的场景】
1)表包含TEXT或者BLOB列;
2)GROUP
BY 或者 DISTINCT 子句中包含长度大于512字节的列;
3)使用UNION或者UNION
ALL时,SELECT子句中包含大于512字节的列;

【临时表相关配置】
tmp_table_size:指定系统创建的内存临时表最大大小;
http://dev.mysql.com/doc/refman/5.1/en/server-system-variables.html#sysvar_tmp_table_size

max_heap_table_size:
指定用户创建的内存表的最大大小;
http://dev.mysql.com/doc/refman/5.1/en/server-system-variables.html#sysvar_max_heap_table_size

注意:最终的系统创建的内存临时表大小是取上述两个配置值的最小值。

【表的设计原则】
使用临时表一般都意味着性能比较低,特别是使用磁盘临时表,性能更慢,因此我们在实际应用中应该尽量避免临时表的使用。

如果实在无法避免,也应该尽量避免使用磁盘临时表。

常见的方法有:

1)创建索引:在ORDER
BY或者GROUP BY的列上创建索引,这样可以避免使用临时表;
2)分拆很长的列,可以避免使用磁盘临时表:一般情况下,TEXT、BLOB,大于512字节的字符串,基本上都是为了显示信息,而不会用于查询条件,因此表设计的时候,应该将这些列独立到另外一张表。

【如何判断使用了临时表?】
使用explain查看执行计划,Extra列看到Using
temporary就意味着使用了临时表。

MySQL官方手册:
http://dev.mysql.com/doc/refman/5.1/en/internal-temporary-tables.html

时间: 2024-12-27 22:43:24

掌握MySQL如何使用临时表,避免踩中性能地雷的相关文章

天山纺织重组搁浅股民踩中“地雷”

幸福的股民都是相似的,不幸的股民却各有各的不幸.在A股市场上,有一种不幸恐怕足以用"杯具"二字来形容,那就是放弃了牛股却踩中了"地雷"!在资产重组的美梦破灭之后,天山纺织(000813,收盘价15.53元)随即跌停,而一位股民在网上"晒"其卖出大牛股西藏发展,买入天山纺织的交易记录,立刻引发不少人的关注. 股民踩中"地雷" 突然公布的一则公告,将天山纺织上万名股东的盈利美梦无情击碎.公司昨日表示,中国证监会上市公司并购重组审核

1w条的excel表格导入mysql数据中性能的问题

问题描述 1w条的excel表格导入mysql数据中性能的问题 业务规则:1w条的excel表格导入mysql数据中,同时要校验数据的完整性和合法行以及判断是否是第一次导入:excel中每行记录对应数据库中两个表:原来的方案是把excel直接导入到临时表中,然后通过存储过程再把临时表数据中满足条件的数据抽取到目标表中:现在发现一个问题导入到临时表话费了将近100秒,再通过存储过程抽取到目标表(占时还没有写存储过程转换)中又将花费好多时间这给用户带来的体验不是很好.在这里请问各位有没有好的解决方案

mysql执行update临时表时崩溃

问题描述 mysql执行update临时表时崩溃 直接上日志:thd: 0x1c1a50f0Attempting backtrace. You can use the following information to find outwhere mysqld died. If you see no messages after this something wentterribly wrong...InnoDB: Thread 9912 stopped in file G:mysql-6.0.1

基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码_php实例

先给大家展示效果图: 查看演示 下载源码 这是一个非常实用的投票实例,应用在双方观点对抗投票场景.用户可以选择支持代表自己观点的一方进行投票,本文以红蓝双方投票为例,通过前后台交互,直观展示红蓝双方投票数和所占比例,应用非常广泛. 本文是一篇综合知识应用类文章,需要您具备PHP.jQuery.MySQL以及html和css方面的基本知识. HTML 我们需要在页面中展示红蓝双方的观点,以及对应的投票数和比例,以及用于投票交互的手型图片,本例以#red和#blue分别表示红蓝双方..redhand

mysql创建存储过程并在php中调用

今天web开发中遇到需要利用php调取mysql的存储过程的,研究了半天终于小有所成,下面将如何使用mysql创建存储过程以及如何使用php调用mysql的存储过程做个记录,以防忘记. 1.在PHPmyadmin中创建一个test1存储过程: create procedure test1(in a int) //create创建:procedure存储过程:test1是存储过程名还管有没有参数都得加上() begin //开始 select * from test where id=a;//这里

如何将MySQL数据导入到Sql Server中

1.安装mysql数据库的ODBC驱动,mysql-connector-odbc-3.51.19-win32.msi 2.打开控制面板\管理工具\数据源ODBC,在用户DSN中添加一个MySQL ODBC 3.51数据源. 3.在登录login选项卡中输入数据源名称Data Source Name,此处输入MysqlDNS;然后输入服务器 Server,用户User,密码Password,输入正确后选择要导入的数据库.在连接选项connect options中根 据需要设置MySql使用的端口p

请问:用java代码mysql如何加载到memcached中?谢谢!!

问题描述 请问:用java代码mysql如何加载到memcached中?谢谢!! 请问:用java代码mysql如何加载到memcached中?谢谢!! 解决方案 你应该是想java调用数据库等访问mysql获取到数据,然后放入memcached等做缓存.

mysql-Java Web连接MySql数据库,修改数据库连接类中的用户名和密码没有效果?

问题描述 Java Web连接MySql数据库,修改数据库连接类中的用户名和密码没有效果? 现在在做一个项目,其中编写了数据库连接及操作的类. 1.ConnDB类. package com.wgh.tools; import java.io.InputStream; //导入java.io.InputStream类 import java.sql.*; //导入java.sql包中的所有类 import java.util.Properties; //导入java.util.Properties

数据库-mysql 获取字符串多个数值中的最大值

问题描述 mysql 获取字符串多个数值中的最大值 如数据YJV-3*50+1*25 取最大值50JKLGYJ-1-120/20 取最大值120YJV-4*70+1*35 取最大值70利用数据库自带函数或自己建立函数或其它方法实现都可以望大家多多帮助 解决方案 用正则 http://stackoverflow.com/questions/5361457/mysql-return-matching-pattern-in-regexp-query 提取出了数据,再排序 解决方案二: 非常感谢@cao