- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要检查以前记录的元素以确保我查询的日期不在结束日期和开始日期前 7 天之间的特定范围内。我有以下代码:
create or replace function eight (date) returns text as $$
declare
r record;
checkDate alias for $1;
begin
for r in
select * from periods
order by startDate
loop
if (checkDate between r.startDate and r.endDate) then
return q3(r.id);
elsif (checkDate between (r.startDate - interval '7 days') and r.startDate) then
return q3(r.id);
elsif (checkDate between (lag(r.endDate) over (order by r.startDate)) and (r.startDate - interval '8 days')) then
return q3(r.id);
end if;
end loop;
return null;
end;
$$ language plpgsql;
所以基本上,我需要检查以下内容:
如果查询日期在起止日期之间
如果查询日期是开始日期开始前7天
如果查询日期在结束日期和开始日期之间并返回与该日期关联的 ID。
在大多数情况下,我的函数似乎工作正常,但有些情况似乎给我 0 个结果(当总是应该有 1 个结果时)我的函数中是否缺少某些东西?我不确定最后一个 if 语句。也就是说,尝试检查从以前的记录结束日期到当前记录的开始日期(有 7 天的间隔)
编辑:没有日期重叠。
最佳答案
编辑:删除了关于 RETURN NEXT 的部分 - 我误读了那里的问题。
无法按照您的方式工作。 window function不能那样称呼。您的记录变量 r
就像 FOR
循环中的内置游标。只有结果的当前行在循环内可见。您必须集成 window function lag()
它进入初始 SELECT
。
但由于无论如何您都在以匹配的顺序遍历行,因此您可以采用另一种方式。
考虑这个很大程度上重写的例子。在第一个违规行返回:
CREATE OR REPLACE FUNCTION q8(_day date)
RETURNS text AS
$BODY$
DECLARE
r record;
last_enddate date;
BEGIN
FOR r IN
SELECT *
-- ,lag(r.endDate) OVER (ORDER BY startDate) AS last_enddate
-- commented, because I supply an alternative solution
FROM periods
ORDER BY startDate
LOOP
IF _day BETWEEN r.startDate AND r.endDate THEN
RETURN 'Violates condition 1'; -- I return differing results
ELSIF _day BETWEEN (r.startDate - 7) AND r.startDate THEN
RETURN 'Violates condition 2';
ELSIF _day BETWEEN last_enddate AND (r.startDate) THEN
-- removed "- 7 ", that is covered above
RETURN 'Violates condition 3';
END IF;
last_enddate := r.enddate; -- remember for next iteration
END LOOP;
RETURN NULL;
END;
$BODY$ LANGUAGE plpgsql;
$1
的别名?您已经在声明中将其命名为 _day
。坚持下去。关于PostgreSQL 检查先前记录的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10257600/
我的应用将 SceneKit 内容的“页面”与图像和文本交替。当我从图像页面前进到新的 SceneKit 页面时,前一个 SceneKit 页面中的内容会短暂显示,然后被新内容替换。时髦。 我只使用一
我正在尝试处理(在 C# 中)包含一些数字数据的大型数据文件。给定一个整数数组,如何对其进行拆分/分组,以便如果下一个 n(两个或更多)是负数,则前一个 n 元素被分组。例如,在下面的数组中,应该使用
刚接触promises,研究过。所以我的代码和我的理解: sql.connect(config).then(function(connection) { return connection.req
目前我在 if (roobaf) block 中有一些代码,这取决于 foo 和 bar 是否为假。我可以在 block 内再次检查这些条件,但感觉像是不必要的代码重复。 if (foo) {
我是一名优秀的程序员,十分优秀!