sql 导航函数 lag

返回上一行中的 value_expression 值。更改 offset 值会改变所返回的上一行;默认值是 1,表示窗口框架中的上一行。
WITH finishers AS
 (SELECT 'Sophia Liu' as name,
  TIMESTAMP '2016-10-18 2:51:45' as finish_time,
  'F30-34' as division
  UNION ALL SELECT 'Lisa Stelzner', TIMESTAMP '2016-10-18 2:54:11', 'F35-39'
  UNION ALL SELECT 'Nikki Leith', TIMESTAMP '2016-10-18 2:59:01', 'F30-34'
  UNION ALL SELECT 'Lauren Matthews', TIMESTAMP '2016-10-18 3:01:17', 'F35-39'
  UNION ALL SELECT 'Desiree Berry', TIMESTAMP '2016-10-18 3:05:42', 'F35-39'
  UNION ALL SELECT 'Suzy Slane', TIMESTAMP '2016-10-18 3:06:24', 'F35-39'
  UNION ALL SELECT 'Jen Edwards', TIMESTAMP '2016-10-18 3:06:36', 'F30-34'
  UNION ALL SELECT 'Meghan Lederer', TIMESTAMP '2016-10-18 3:07:41', 'F30-34'
  UNION ALL SELECT 'Carly Forte', TIMESTAMP '2016-10-18 3:08:58', 'F25-29'
  UNION ALL SELECT 'Lauren Reasoner', TIMESTAMP '2016-10-18 3:10:14', 'F30-34')
SELECT name,
  finish_time,
  division,
  LAG(name)
    OVER (PARTITION BY division ORDER BY finish_time ASC) AS preceding_runner
FROM finishers;


namefinish_timedivisionpreceding_runner
Carly Forte03:08:58F25-29NULL
Sophia Liu02:51:45F30-34NULL
Nikki Leith02:59:01F30-34Sophia Liu
Jen Edwards03:06:36F30-34Nikki Leith
Meghan Lederer03:07:41F30-34Jen Edwards
Lauren Reasoner03:10:14F30-34Meghan Lederer
Lisa Stelzner02:54:11F35-39NULL
Lauren Matthews03:01:17F35-39Lisa Stelzner
Desiree Berry03:05:42F35-39Lauren Matthews
Suzy Slane03:06:24F35-39Desiree Berry
下一个示例使用可选的 offset 参数
WITH finishers AS
 (SELECT 'Sophia Liu' as name,
  TIMESTAMP '2016-10-18 2:51:45' as finish_time,
  'F30-34' as division
  UNION ALL SELECT 'Lisa Stelzner', TIMESTAMP '2016-10-18 2:54:11', 'F35-39'
  UNION ALL SELECT 'Nikki Leith', TIMESTAMP '2016-10-18 2:59:01', 'F30-34'
  UNION ALL SELECT 'Lauren Matthews', TIMESTAMP '2016-10-18 3:01:17', 'F35-39'
  UNION ALL SELECT 'Desiree Berry', TIMESTAMP '2016-10-18 3:05:42', 'F35-39'
  UNION ALL SELECT 'Suzy Slane', TIMESTAMP '2016-10-18 3:06:24', 'F35-39'
  UNION ALL SELECT 'Jen Edwards', TIMESTAMP '2016-10-18 3:06:36', 'F30-34'
  UNION ALL SELECT 'Meghan Lederer', TIMESTAMP '2016-10-18 3:07:41', 'F30-34'
  UNION ALL SELECT 'Carly Forte', TIMESTAMP '2016-10-18 3:08:58', 'F25-29'
  UNION ALL SELECT 'Lauren Reasoner', TIMESTAMP '2016-10-18 3:10:14', 'F30-34')
SELECT name,
  finish_time,
  division,
  LAG(name, 2)
    OVER (PARTITION BY division ORDER BY finish_time ASC) AS two_runners_ahead
FROM finishers;


namefinish_timedivisiontwo_runners_ahead
Carly Forte03:08:58F25-29NULL
Sophia Liu02:51:45F30-34NULL
Nikki Leith02:59:01F30-34NULL
Jen Edwards03:06:36F30-34Sophia Liu
Meghan Lederer03:07:41F30-34Nikki Leith
Lauren Reasoner03:10:14F30-34Jen Edwards
Lisa Stelzner02:54:11F35-39NULL
Lauren Matthews03:01:17F35-39NULL
Desiree Berry03:05:42F35-39Lisa Stelzner
Suzy Slane03:06:24F35-39Lauren Matthews
以下示例使用默认值替换 NULL 值
WITH finishers AS
 (SELECT 'Sophia Liu' as name,
  TIMESTAMP '2016-10-18 2:51:45' as finish_time,
  'F30-34' as division
  UNION ALL SELECT 'Lisa Stelzner', TIMESTAMP '2016-10-18 2:54:11', 'F35-39'
  UNION ALL SELECT 'Nikki Leith', TIMESTAMP '2016-10-18 2:59:01', 'F30-34'
  UNION ALL SELECT 'Lauren Matthews', TIMESTAMP '2016-10-18 3:01:17', 'F35-39'
  UNION ALL SELECT 'Desiree Berry', TIMESTAMP '2016-10-18 3:05:42', 'F35-39'
  UNION ALL SELECT 'Suzy Slane', TIMESTAMP '2016-10-18 3:06:24', 'F35-39'
  UNION ALL SELECT 'Jen Edwards', TIMESTAMP '2016-10-18 3:06:36', 'F30-34'
  UNION ALL SELECT 'Meghan Lederer', TIMESTAMP '2016-10-18 3:07:41', 'F30-34'
  UNION ALL SELECT 'Carly Forte', TIMESTAMP '2016-10-18 3:08:58', 'F25-29'
  UNION ALL SELECT 'Lauren Reasoner', TIMESTAMP '2016-10-18 3:10:14', 'F30-34')
SELECT name,
  finish_time,
  division,
  LAG(name, 2, 'Nobody')
    OVER (PARTITION BY division ORDER BY finish_time ASC) AS two_runners_ahead
FROM finishers;


namefinish_timedivisiontwo_runners_ahead
Carly Forte03:08:58F25-29Nobody
Sophia Liu02:51:45F30-34Nobody
Nikki Leith02:59:01F30-34Nobody
Jen Edwards03:06:36F30-34Sophia Liu
Meghan Lederer03:07:41F30-34Nikki Leith
Lauren Reasoner03:10:14F30-34Jen Edwards
Lisa Stelzner02:54:11F35-39Nobody
Lauren Matthews03:01:17F35-39Nobody
Desiree Berry03:05:42F35-39Lisa Stelzner
Suzy Slane03:06:24F35-39Lauren Matthews
posted @ 2022-08-19 22:50  luoganttcc  阅读(9)  评论(0)    收藏  举报