SQL语句多层嵌套查询很慢,怎么优化,求方案
答案:1 悬赏:0 手机版
解决时间 2021-12-02 01:51
- 提问者网友:半生酒醒
- 2021-12-01 10:55
SQL语句多层嵌套查询很慢,怎么优化,求方案
最佳答案
- 五星知识达人网友:零点过十分
- 2021-12-01 12:22
大致的看了下,有点晕,内嵌的几个select只是对同一个表的部分不同条件进行分组计算,没必要写两个查询,其中还嵌套一个,我也是醉了,可以用case-when去解决这个问题。追问casewhen怎么用呀,求示例追答比如 字段大于10的值加1,小于10的减一,
select
* ,
case when 字段值>10 then 字段值+1 else 字段值-1 end as 自定义列名
from tablename
你那边好像是同一个表不同条件,不同计算(有两列),可以这么写
select *,
case when 条件1 then sum(此处计算和) else 0 end as condition1,
case when 条件2 then sum(此处计算和) else 0 end as condition2
from tablename
大致就是这么写的,自己研究些,能学的更多,别人讲的太明白话学的反而少。追问case when 条件只能是一个判断条件,那个日期在一段时间内,且降雨不为空,这么多条件casewhen能判定吗追答可以,在when后面的条件跟写在where后面没区别。追问还是不太会,大神帮我该下呗,急求
select
* ,
case when 字段值>10 then 字段值+1 else 字段值-1 end as 自定义列名
from tablename
你那边好像是同一个表不同条件,不同计算(有两列),可以这么写
select *,
case when 条件1 then sum(此处计算和) else 0 end as condition1,
case when 条件2 then sum(此处计算和) else 0 end as condition2
from tablename
大致就是这么写的,自己研究些,能学的更多,别人讲的太明白话学的反而少。追问case when 条件只能是一个判断条件,那个日期在一段时间内,且降雨不为空,这么多条件casewhen能判定吗追答可以,在when后面的条件跟写在where后面没区别。追问还是不太会,大神帮我该下呗,急求
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯