优化问题急

utpcb 2011-11-09 08:55:17

select m.c5 c5,m.co co,max(m.c1) c1 from ST1401_main m join (
select c5,co, CAST(date_add(max(c1),interval -1 month) AS UNSIGNED) c1 ,max(c1) from ST1401_main
where c5>=20111231000000 and c5<=20121231000000 group by c5,co ) n on m.c5=n.c5 and m.co=n.co and
m.c1<n.c1 group by m.c5,m.co


1 PRIMARY <derived2> ALL \N \N \N \N 4686 Using temporary; Using filesort
1 PRIMARY m ref PRIMARY,C1,C5,C5COC1 C5COC1 107 n.c5,n.co 296 Using where; Using index
2 DERIVED ST1401_main range C5,C5COC1 C5COC1 107 \N 6055 Using where; Using index for group-by

就是第一步那个应该 怎么优化呢
...全文
295 36 打赏 收藏 转发到动态 举报
写回复
用AI写文章
36 条回复
切换为时间正序
请发表友善的回复…
发表回复
utpcb 2011-11-21
  • 打赏
  • 举报
回复
看看还有没有人
utpcb 2011-11-17
  • 打赏
  • 举报
回复
有实验过么 你说的第一步我弄过第二步 不敢弄
jinguanding 2011-11-16
  • 打赏
  • 举报
回复
select m.c5 c5,m.co co,max(m.c1) c1 from ST1401_main m join (
select c5,co, CAST(date_add(max(c1),interval -1 month) AS UNSIGNED) c1 ,max(c1) from ST1401_main
where c5>=20111231000000 and c5<=20121231000000 group by c5,co ) n on m.c5=n.c5 and m.co=n.co and
m.c1<n.c1 group by m.c5,m.co


1 PRIMARY <derived2> ALL \N \N \N \N 4686 Using temporary; Using filesort
1 PRIMARY m ref PRIMARY,C1,C5,C5COC1 C5COC1 107 n.c5,n.co 296 Using where; Using index
2 DERIVED ST1401_main range C5,C5COC1 C5COC1 107 \N 6055 Using where; Using index for group-by

就是第一步那个应该 怎么优化呢

第一步:
从你的需求看,可以考虑借助索引覆盖的技巧解决,即创建索引:
ALTER TABLE ST1401_main ADD INDEX idx_c5_co_c1(c5,co,c1);

第二步:
SET GLOBAL JOIN_BUFFER_SIZE=1024*1024*16;
SET GLOBAL TMP_BUFFER_SIZE=1024*1024*64;
SET GLOBAL HEAP_BUFFER_SIZE=1024*1024*64;

SET GLOBAL READ_BUFFER_SIZE=1024*1024*2;


#****************************************#
MySQL技术及运维自动化网:www.mysqlops.com

新浪微博账号:http://weibo.com/mysqlops
#****************************************#
utpcb 2011-11-10
  • 打赏
  • 举报
回复
我已经提交上去咯 大神能帮我看看么
utpcb 2011-11-10
  • 打赏
  • 举报
回复
在服务器上 我只能倒出来看
utpcb 2011-11-10
  • 打赏
  • 举报
回复
几百万的数据提供是不可能的啦
ACMAIN_CHM 2011-11-10
  • 打赏
  • 举报
回复
建议提供你的数据,这样别人可以直接在自己机器上进行调试分析。 你可以直接将目录中的`ST1401_main` .* 的三个文件打包上传。

可以上传到 http://www.access911.net/csdn
utpcb 2011-11-10
  • 打赏
  • 举报
回复
在你们的建议之前我已经这样做过了! 是不是有别的方法该语句呢
utpcb 2011-11-09
  • 打赏
  • 举报
回复
也咩用 我试过啊
ACMAIN_CHM 2011-11-09
  • 打赏
  • 举报
回复
主要是试一下STRAIGHT_JOIN
utpcb 2011-11-09
  • 打赏
  • 举报
回复
之前也试过哦还有 CAST(date_add(max(c1),interval -1 month) AS UNSIGNED) 一定要用这样的 不然类型不对查不出数据!
ACMAIN_CHM 2011-11-09
  • 打赏
  • 举报
回复
select STRAIGHT_JOIN m.c5 ,m.co ,max(m.c1)
from (
select c5,co, max(c1) - interval 1 month as c1
from ST1401_main
where c5>=20111231000000 and c5<=20121231000000
group by c5,co
) n inner join ST1401_main m
on m.c5=n.c5
and m.co=n.co
and m.c1<n.c1
group by m.c5,m.co


试一下。
utpcb 2011-11-09
  • 打赏
  • 举报
回复
前面贴错了不好意思

ST1401_main 0 PRIMARY 1 CO A \N \N \N BTREE
ST1401_main 0 PRIMARY 2 C20 A 3703760 \N \N BTREE
ST1401_main 1 CV 1 CV A 3703760 \N \N YES BTREE
ST1401_main 1 C1 1 C1 A 690 \N \N YES BTREE
ST1401_main 1 C2 1 C2 A 4 \N \N YES BTREE
ST1401_main 1 C5 1 C5 A 7 \N \N YES BTREE
ST1401_main 1 C19 1 C19 A 1 \N \N YES BTREE
ST1401_main 1 C5COC1 1 C5 A 7 \N \N YES BTREE
ST1401_main 1 C5COC1 2 CO A 12512 \N \N BTREE
ST1401_main 1 C5COC1 3 C1 A 3703760 \N \N YES BTREE
ACMAIN_CHM 2011-11-09
  • 打赏
  • 举报
回复
你贴出的INDEX中并没有 `C5COC1` (`C5`,`CO`,`C1`) 的索引啊? 你贴完整了吗?
utpcb 2011-11-09
  • 打赏
  • 举报
回复
索引我可以强制指定的 就是那个<变成= 也就快了 我要的是一个月前的最大值哦 怎么要4秒钟
utpcb 2011-11-09
  • 打赏
  • 举报
回复

SHOW INDEX FROM ST41010_main
ST41010_main 0 PRIMARY 1 CO A 1 \N \N BTREE
ST41010_main 0 PRIMARY 2 C10 A 35 \N \N BTREE
ST41010_main 1 CV 1 CV A 35 \N \N YES BTREE
ST41010_main 1 C1 1 C1 A 35 \N \N YES BTREE
ST41010_main 1 C2 1 C2 A 35 \N \N YES BTREE
ST41010_main 1 C9 1 C9 A 2 20 \N YES BTREE
GIS_Cloud 2011-11-09
  • 打赏
  • 举报
回复
KEY `CV` (`CV`),
KEY `C1` (`C1`),
KEY `C2` (`C2`),
KEY `C5` (`C5`),
KEY `C19` (`C19`),
KEY `C5COC1` (`C5`,`CO`,`C1`)
---------
这几个是他的key吧
ACMAIN_CHM 2011-11-09
  • 打赏
  • 举报
回复
你的 show index 呢?怎么没有贴出来?
wwwwb 2011-11-09
  • 打赏
  • 举报
回复
[Quote=引用 12 楼 utpcb 的回复:]
索引都建好了萨 你们说的临时表我直接就已经玩过了撒!就是不行撒 头大撒
[/Quote]
你的临时表怎么建立的,相应的索引加上没有

ST1401_main:去掉C5、C1的索引
utpcb 2011-11-09
  • 打赏
  • 举报
回复
ST1401_main CREATE TABLE `ST1401_main` (
`CV` bigint(20) DEFAULT NULL,
`CKey` char(32) COLLATE utf8_bin DEFAULT NULL,
`CO` varchar(32) COLLATE utf8_bin NOT NULL DEFAULT '',
`C1` bigint(20) DEFAULT NULL,
`C2` int(10) unsigned DEFAULT NULL,
`C3` bigint(20) DEFAULT NULL,
`C4` int(10) unsigned DEFAULT NULL,
`C5` bigint(20) DEFAULT NULL,
`C6` double DEFAULT NULL,
`C7` double DEFAULT NULL,
`C8` double DEFAULT NULL,
`C9` double DEFAULT NULL,
`C10` double DEFAULT NULL,
`C11` double DEFAULT NULL,
`C12` double DEFAULT NULL,
`C13` double DEFAULT NULL,
`C14` double DEFAULT NULL,
`C15` double DEFAULT NULL,
`C16` double DEFAULT NULL,
`C17` double DEFAULT NULL,
`C18` double DEFAULT NULL,
`C19` int(10) unsigned DEFAULT NULL,
`C20` int(10) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (`CO`,`C20`),
KEY `CV` (`CV`),
KEY `C1` (`C1`),
KEY `C2` (`C2`),
KEY `C5` (`C5`),
KEY `C19` (`C19`),
KEY `C5COC1` (`C5`,`CO`,`C1`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin


你们有没有注意到

要是把m.c1<(n.c1-100000000) 改为 m.c1=(n.c1-100000000)执行计划一样的 只要500毫秒 之前的要4秒! 这个数据大概300W的 我想要的效果是 1秒钟出来 有谁有好的方法啊
加载更多回复(16)
最近有人说下不了,我看了一下,能下载,多尝试几次~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 找来一个很有用的声卡驱动解决方案,是我尝试了n次(不下20)还搭上某人的辛苦劳动,才成功让我的Win7发出声音的!!!以下是引用本站“实话实说”的博客。。。 你看到这篇文章时候估计你快被windows7无法安装声卡驱动而崩溃了,呵呵,别,这篇文章是你的救星,本人已经试验多台电脑,完美解决windows7声卡驱动安装失败这一问题 有个前提,你已经有适合自己机子声卡驱动就是总是安装失败,若没有声卡驱动可以用驱动人生(或者其他驱动检测设备)检测并下载适合自己的驱动以备下一步使用。 闲话少说,正文: 1.先下载解压 windows7声卡驱动修复 压缩包。 2.打开你系统的所在盘进入Windows-system32-Driverstore-FileRepository在里面找到wdmaudio.inf_x86_neutral_aed2a4456700dfde文件夹. 一个一个慢慢找吧别着. 4.再进入(wdmaudio.inf_x86_neutral_aed2a4456700dfde)文件夹把里面的东西全删了(删不掉,因为需要管理员权限 ,用windows7 优化大师 -->系统设置--->又键设置--->获取管理员权限(文件\文件夹)--应用到系统,然后对删不掉的文件点右键 --获取管理员权限---删除) 5.回到你刚刚解压的文件夹 6.把里面文件全部复制粘贴到wdmaudio.inf……文件夹里面 7.重新安装声卡驱动. 8.重启ok 问题解决了 如果没有WIN7驱动程序,用vista的也可以
酷窗版演示:http://www.edd8.com/bbs/index.asp?style=0 简装版演示:http://www.edd8.com/bbs/index2.asp 一点点论坛(http://www.edd8.com/bbs)使用说明 欢迎大家下载使用一点点论坛,在使用论坛前,请认真阅读以下内容: ===================================== 论坛:一点点论坛(http://www.edd8.com/bbs) 主页:一点点星空驿站(http://www.edd8.com/) 站长:叮咚虫(e_Mail:b_li@163.com) 版本:EDD8 Ver.2003 for DV =====================================   一点点论坛是建立在动网论坛基础上的ASP互动论坛,从动网Var5.b109开始论坛结构便开始脱离动网,与动网升级一起,本论坛本身也同时实现了动网新的功能,到519的发布,本人常得论坛本身已功能基本完善,所以决定与动网完全脱离,到动网Final的出现,本论坛也决定不再跟随动网升级了,本人全面对原来的论坛进行了代码优化和版面重排,并升级了部分功能代码,完成了现在这样的论坛。使论坛已经完全脱离了动网,以后也不可以随动网一起升级了!   所以选择本论坛的朋友请先明白,如果采用了本论坛的数据结构,以后就不可以和动网一起升级了,而现有的动网Final版的数据库和本论坛的数据库也是不兼容的!对于动网V5.b519的用户,本人同时在压缩包里提供了升级文件,可以把你519的数据库升级成和本论坛一致的数据结构!   由于一些朋友催得较,部分功能还是没有完善的(但不会出错),我以后也会给出升级包的。所以决定使用本论坛的朋友,请一定要到本站论坛的“站务办公室”进行指定的留言签名,以好我第一时间通知大家升级!   论坛中使用到的部分插件并没有一同奉上,原因是我还没完成代码优化,请过几天到我的论坛上下载。可以下载的插件主要有:社区银行、网络拳皇、可乐吧台球、五子棋等等…… ===================================== 主要特色功能说明: ◎ 双版面设计,用户可以根据不同爱好选择不同的版式(酷窗版和精简版),系统会记录用户的选择,不用重复选择,也不会出现版面混淆等现象; ◎ 发贴回贴互动功能,给用户随机的互动事件,增加用户的参与兴趣; ◎ 增强的UBB代码和JS代码,新增的买卖贴、定时贴等十几种特色功能UBB代码; ◎ 贴子功能加强,增加互动鲜花、鸡蛋、金钱、炸弹等功能,并保存数据作为用户在论坛的人缘依据; ◎ 不好说了,等你去发掘吧,不然又说我叫卖了…… ====================================== 安装说明: 解压就可以了,数据库名称和路径有变动时不要忘了在CONN。ASP中进行相应修改。 (注意:当论坛中一个贴子也没有时,论坛明星会出错,但当你加入贴子后就正常了,大家不要惊慌) 升级:(对519),解压后把你的原519数据库覆盖现数据库,再执行根目录下的UPDATE。ASP文件就行了,如果没有升级成功的提示,说明你的数据不能进行升级! (注意:数据库的升级应做了备份,并在本机上进行!) ====================================== 最后一点说明: 由于论坛本来是打算自己用的,所以在设计的过程中部分变量已经去掉,不能从后台设置了(如表格边框),请大家最好保持现有的风格。 如果还不问题,可以到我的论坛上来交流。??注意,由于本人时间不限,技术支持是有限的,请不要过于强求!

56,685

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧