- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一些这样的表。
create table programming_language(
id smallserial primary key,
name text not null,
initial_users integer not null,
initial_release date not null
);
create table usage_data(
id smallserial primary key,
language_id integer references programming_language(id),
percent_users_change decimal(5,2),
increase_or_decrease boolean default False, -- false indicates decrease
survey_year integer not null
);
现在每个编程语言都有一个初始用户数,如表编程语言的 initial_users 中给定的那样。 usage_data 有 percent_users_change 列,它为我们提供了与前几年相比用户数量增加或减少的百分比。是减少还是增加由 increase_or_column 列给出。现在我需要查询并查找每个 survey_year 中的用户数。我编写了以下查询来实现此目的,但我无法做到,因为您无法在同一个选择查询中引用该变量。
select language_id,case when increase_or_decrease=True then percent_users_change+(lag(previ,0) over(partition by language_id order by survey_year))
when increase_or_decrease=False then percent_users_change-(lag(previ,0) over(partition by language_id order by survey_year))
end as previ
from usage_data;
示例数据:
+----+-------------+----------------------+----------------------+-------------+
| id | language_id | percent_users_change | increase_or_decrease | survey_year |
+----+-------------+----------------------+----------------------+-------------+
| 1 | 1 | 10 | True | 1991
| 2 | 1 | 7.5 | True | 1993 |
| 3 | 3 | 12.5 | True | 1996 |
| 4 | 4 | 8.75 | True | 1996 |
+----+-------------+----------------------+----------------------+-------------+
例如,对于语言 1,如果初始用户是 10,对于 1991 年,我希望它是 11(上一年的 10+10%),1992 之后它应该是 11.825(11+11 的 7.5%) ) 等等。
最佳答案
可以从初始用户计算百分比变化
pct_change(i) = init_users * prod_from_0_i(pct_change)
其中 pct_change
表示为 1 +/- percent_users_change/100
例如
# for language 1, init_users = 10
1991 (change 10%) -> 10 * (1.10) = 11
1993 (change 7.5%) -> 10 * (1.10)(1.075) = 11.825
为此我们需要一个 Product 聚合函数,它没有在 SQL 中实现,但是,我们可以实现它取对数,我们可以应用 SUM
聚合函数。
这是因为以下身份:
log(xy) = log(x) + log(y)
将其推广到一系列 xs
log(xs) = log(x0) + log(x1) + ..., where x0,x1,... <- xs
= sum(log(x | x <- xs))
和
x = exp(log(x))
即exp
& log
是反函数。
另外,请注意 log
未定义为 0 和负值。
结合这两个身份,我们得到:
exp(SUM(ln(x) | x <- xs, x > 0)) === prod(xs)
因此,我们可以将查询写成:
WITH united AS (
SELECT
EXTRACT(YEAR FROM initial_release) yr
, id
, initial_users :: NUMERIC users
, 1.0 change
FROM programming_language
UNION ALL
SELECT
survey_year yr
, language_id id
, null
, case when increase_or_decrease
then 1 + (percent_users_change / 100.0)
else 1 - (percent_users_change / 100.0) end change
FROM usage_data
)
SELECT yr, id,
FIRST_VALUE(users) OVER w * EXP(SUM(LN(u.change)) OVER w) users
FROM united u
WINDOW w as (PARTITION BY id ORDER BY yr ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW)
这里先统一初始数据和后期使用数据计算change
列,然后从初始users计算连续年份的
。users
关于sql - Postgresql - 引用之前计算的列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50561502/
我正在寻找一种使此打印 HTML 代码 fragment 向后兼容旧 Android 版本的简单方法: @TargetApi(Build.VERSION_CODES.KITKAT) private v
我在 GCC 终端 (centos linux) 中为 ATM 项目编译以下 c 和 .h 代码时收到以下错误。请帮忙,因为我是编程新手。 validate_acc.h #ifndef _VALIDA
在写关于 SO 的不同问题的答案时,我制作了这个片段: @import url('https://fonts.googleapis.com/css?family=Shadows+Into+Light'
试图弄清楚我应该如何在 my_div_class 之前放置一个 span 而不是替换所有它。现在它取代了 div,但我不想这样做。我假设它类似于 :before 但不知道如何使用它。 { va
我正在使用选择库 http://github.hubspot.com/select/和 noUiSlider https://refreshless.com/nouislider/ .我面临的问题如下
我是开发新手,独自工作。我正在使用 Xcode 和 git 版本控制。可能我没有适本地组织和做错事,但我通常决定做 promise 只是为了在我破坏一切之前做出安全点。在那一刻,我发现很难恰本地描述我
我想确保在同一个桶和键上读取和写入时,应该更新获取的值,也就是说,应该在对其进行写入操作之后获取它。我怎样才能做到这一点? 我想要的是,如果我更新一个键的值,如果我同时使用不同线程获取值,则更新同一个
我的问题与this有关问题,已经有了答案: yes, there is a happens-before relationship imposed between actionsof the thre
The before and after hook documentation on Relish仅显示 before(:suite) 在 before(:all) 之前调用。 我什么时候应该使用其中
我有 CSV 行,我想在其中检测所有内部双引号,没有文本限定符。这几乎可以正常工作,但我的正则表达式还可以检测双引号后的字符。 CSV 部分: "7580";"Lorem ipsum";"";"Lor
是否可以通过Youtube数据API检查广告是否可以与特定视频一起显示? 我了解contentDetails.licensedContent仅显示视频是否已上传至同一伙伴然后由其声明版权。由于第三者权
考虑一下用漂亮的彩色图表描述的“像素管道” https://developers.google.com/web/fundamentals/performance/rendering/ 我有一个元素(比
之前?
在 MVC3 中,我可以轻松地将 jQuery 脚本标签移动到页面底部“_Layout.vbhtml” 但是,在 ASP.NET MVC3 中,当您使用编辑器模板创建 Controller 时,脚手
悬停时内容被替换,但是当鼠标离开元素时我希望它变回来。我该怎么做? $('.img-wrap').hover(function(){ $(this).find('h4').text('Go
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 已关闭 9 年前。 有关您编写的代码问题的问题必须在问题本身中描述具体问题 - 并包含有效代码以重现该问题。
版本:qwt 6.0.1我尝试开发频谱的对数缩放。我使用简单的线条来启用缩放plotspectrum->setAxisScaleEngine(QwtPlot::yLeft, new QwtLog10S
我有两个相同的表,I_Subject 和 I_Temp_Subject,我想将 Temp_Subject 表复制到 Subject 表。 I_Temp_Subject 由简单用户使用,I_Subjec
我的印象是第一次绘制发生在触发 DOMContentLoaded 事件之后。特别是,因为我认为为了让第一次绘制发生,需要渲染树,它依赖于 DOM 构造。另外,我知道 DOM 构造完成时会触发 DOMC
我是一名优秀的程序员,十分优秀!