Mysql使用视图加速查询

博客介绍了在 MySQL 中,对表的子集排序并创建视图可加速查询。这样能避免多次排序,简化优化器工作。如将未付款客户找出放在视图并按名字排序,视图行少且顺序符合要求,可减少磁盘 I/O,大幅降低查询工作量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

SELECT cust.name,rcvbles.balance,……other columns
FROM cust,rcvbles
WHERE cust.customer_id = rcvlbes.customer_id
AND rcvblls.balance>0
AND cust.postcode>98000ORDER BY cust.name

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

CREATE VIEW DBO.V_CUST_RCVLBES AS
SELECT cust.name,rcvbles.balance,……other columns
FROM cust,rcvbles
WHERE cust.customer_id = rcvlbes.customer_id
AND rcvblls.balance>0
ORDER BY cust.name

然后以下面的方式在视图中查询:

SELECT * FROM V_CUST_RCVLBES WHERE postcode>98000

视图中的行要比主表中的行少,而且物理顺序就是所要求的顺序,减少了磁盘 I/O,所以查询工作量可以得到大幅减少。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值