使用MySQL临时表加速查询

数据库 MySQL
使用MySQL临时表,有时能加速查询,下文对该方法进行了详细的介绍分析,如果您对此方面感兴趣的话,不妨一看。

使用MySQL临时表,有时是可以加速查询的,下面就为您详细介绍使用MySQL临时表加速查询的方法,希望对您有所帮助。

把表的一个子集进行排序并创建MySQL临时表,有时能加速查询。它有助于避免多重排序操作,而且在其他方面还能简化优化器的工作。例如:

  1. SELECT cust.name,rcVBles.balance,……other columns  
  2.  
  3. SELECT cust.name,rcVBles.balance,……other columns  
  4.  
  5. FROM cust,rcvbles  
  6.  
  7. WHERE cust.customer_id = rcvlbes.customer_id  
  8.  
  9. AND rcvblls.balance>0  
  10.  
  11. AND cust.postcode>“98000”  
  12.  
  13. ORDER BY cust.name   

如果这个查询要被执行多次而不止一次,可以把所有未付款的客户找出来放在一个临时文件中,并按客户的名字进行排序:

  1. SELECT cust.name,rcvbles.balance,……other columns  
  2.  
  3. SELECT cust.name,rcvbles.balance,……other columns  
  4.  
  5. FROM cust,rcvbles  
  6.  
  7. WHERE cust.customer_id = rcvlbes.customer_id  
  8.  
  9. AND rcvblls.balance>0  
  10.  
  11. ORDER BY cust.name  
  12.  
  13. INTO TEMP cust_with_balance   

然后以下面的方式在临时表中查询: SELECT * FROM cust_with_balance

WHERE postcode>“98000”
临时表中的行要比主表中的行少,而且物理顺序就是所要求的顺序,减少了磁盘I/O,所以查询工作量可以得到大幅减少。

注意:临时表创建后不会反映主表的修改。在主表中数据频繁修改的情况下,注意不要丢失数据。


 

 

 

【编辑推荐】

查看MySQL二进制日志的方法

mysql日志文件的详细说明

重定位MySQL数据目录的方法

MySQL数据库表的表示

MySQL数据目录的位置

责任编辑:段燃 来源: 互联网
相关推荐

2010-05-17 16:31:48

Mysql临时表

2024-04-03 09:12:03

PostgreSQL索引数据库

2010-11-24 10:05:20

mysql创建临时表

2010-11-22 15:19:28

Mysql临时表

2024-10-17 16:17:21

MySQL临时表数据库

2009-07-02 11:29:30

MySQL参数

2010-07-22 15:56:04

SQL Server临

2010-11-12 13:27:13

动态sql

2022-04-26 09:44:03

group byExtraMySQL

2010-10-15 11:27:21

Mysql临时表

2010-05-19 09:01:14

MySQL临时表

2014-09-25 09:43:29

临时表表变量SQL

2024-01-11 10:12:19

MySQL数据库

2010-05-31 15:49:29

MySQL临时表

2021-11-11 15:03:35

MySQLSQL索引

2021-11-07 23:46:32

MySQLSQL索引

2023-05-26 16:40:22

临时表Hive数据表存储

2011-04-13 13:56:52

Oracle临时表

2011-09-02 14:45:43

Oracle临时表SQL Server临

2013-09-26 14:11:23

SQL性能优化
点赞
收藏

51CTO技术栈公众号