Sql2008 R2
(1)有4个视图,每一个视图,来自6张表, 这个视图有2800万行数据,查询非常慢可能要10个小时,甚至没结果,电脑挂掉,想提速,给点建议吧,有时候,where条件复杂了程序执行几十分钟后挂掉,查不出结果的.
(2)每张表之间没有主外建关系,或者没有主键,【但有索引】,因为数据是从HIS系统采集过来的.所有数据只需要查询,不需要修改和删除.
(3)大部分表有70-80列, 单个表 最多 600万行记录.
(4)用户需要提交非常复杂的 where 条件 以对数据统计.
例如 年月日,姓名,数量,次数,科次等20个以上的条件.
(5)
过程大概分2步,
1: 按用户提交的where 条件筛选数据,形成一张非常大的 临时表或称做table的.
2:在第1步筛选的基础上进行count,sum等40个或以上的统计,再返回结果,可能还有其它嵌套统计或判断
每次提交的where 条件是动态的
largeQ
炎炎设计