本来你的语句很漂亮,用不着优化。如果你实在很关心性能,可以在WHERE部分限制一下【净入库.`入库日期`】的时间范围在1~9月,避免全表浏览,如果该字段有索引,可以快一点点。
AND 净入库.`入库日期` BETWEEN '2016-01-01 00:00:00.0' AND '2016-09-30 00:00:00.0'
SELECTzc.纳税人名称,
sum(CASE
WHEN 净入库.`征收项目` = '城镇土地使用税' THEN
净入库.实缴金额
ELSE
0
END) 土地使用税,
sum(CASE
WHEN 净入库.`征收项目` = '房产税' THEN
净入库.实缴金额
ELSE
0
END) 房产税
FROM
清册 zc,
净入库
WHERE
zc.`登记序号` =净入库.登记序号
AND 净入库.`入库日期` BETWEEN '2016-01-01 00:00:00.0' AND '2016-09-30 00:00:00.0'
group by zc.`登记序号`
mysql优化是一个大方向,大的是要分布式、读写分离,小的是对sql语句进行优化。不过大多问的也是对sql语句优化,网上很多资料,我就大体说说。1、explain+索引。
在你要查询的语句前加explain,看下有没有用到索引,如果出现type为all的,则说明有必要添加下索引。(附多表查询速度比较:表关联>exists>in)慢查询优化是一大块。
2、预统计。
很经常需要对历史的数据进行过滤统计。比如移动需要统计上个月电话小时数超过N小时的人,那么如果直接取原始数据,那将很慢,此时如果每天晚上凌晨都对数据进行预统计,统计每个人每天电话时数,那再来过滤就很快。
3、分表分区。
分表分区也是为了提高搜索速度。例如,公交车的gps行驶记录,gps每隔15s报一次,一辆车一天运行12小时,一天就要插入4*60*12条记录,N辆车就要再乘,其数量极大,所以经常按月分表,分表里再按上报时间做日分区,这样就达到很大的优化,想查询某段时间,mysql很快就可以定位到。
4、表结构。
表结构很重要,经常需要多表关联查询一些字段,有时可以冗余下放到同一张表。
mysql优化很有意思,多去查阅些资料,多去尝试,对你有好处的。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)