加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql应用MySQL使用临时表加速查询的方法

发布时间:2020-12-12 02:31:12 所属栏目:MySql教程 来源:网络整理
导读:《Mysql应用MySQL使用临时表加速查询的方法》要点: 本文介绍了Mysql应用MySQL使用临时表加速查询的方法,希望对您有用。如果有疑问,可以联系我们。 本篇章节讲解MySQL使用临时表加速查询的办法.供大家参考研究.具体分析如下: MYSQL教程 使用MySQL

《Mysql应用MySQL使用临时表加速查询的方法》要点:
本文介绍了Mysql应用MySQL使用临时表加速查询的方法,希望对您有用。如果有疑问,可以联系我们。

本篇章节讲解MySQL使用临时表加速查询的办法.分享给大家供大家参考.具体分析如下:MYSQL教程

使用MySQL临时表,有时是可以加速查询的,下面就为您详细介绍使用MySQL临时表加速查询的办法.MYSQL教程

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

代码如下: SELECT cust.name,rcVBles.balance,……other columns?
SELECT cust.name,……other columns?
FROM cust,rcvbles?
WHERE cust.customer_id = rcvlbes.customer_id?
AND rcvblls.balance>0?
AND cust.postcode>"98000"?
ORDER BY cust.name
如果这个查询要被执行多次而不止一次,可以把所有未付款的客户找出来放在一个临时文件中,并按客户的名字进行排序:
代码如下: SELECT cust.name,rcvbles.balance,rcvbles?
WHERE cust.customer_id = rcvlbes.customer_id?
AND rcvblls.balance>0?
ORDER BY cust.name?
INTO TEMP cust_with_balance
然后以下面的方式在临时表中查询:
代码如下: SELECT * FROM cust_with_balance
WHERE postcode>"98000"
临时表中的行要比主表中的行少,而且物理顺序就是所要求的顺序,减少了磁盘I/O,所以查询工作量可以得到大幅减少.

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

希望本文所述对大家的MySQL数据库程序设计有所赞助.MYSQL教程

编程之家PHP培训学院每天发布《Mysql应用MySQL使用临时表加速查询的方法》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读