Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
0 / 0 / 2
Регистрация: 22.04.2015
Сообщений: 70

Использование LAG, исключая поля NULL

27.01.2020, 12:48. Показов 3424. Ответов 2
Метки lag (Все метки)

Студворк — интернет-сервис помощи студентам
Все привет.
Работаю с PostgreSQL. Есть такая задача, если запрос возвращает NULL подставлять значение из предыдущей строки.
Для таких целей использую функция LAG.
Но с ней есть одна проблемка: если в столбце присутствую подряд более одной ячейки NULL то все направстно, нужно найти первую ячейку с NOTNULL значением.
Пробую
SQL
1
LAG (bb.dw214 NOTNULL) OVER(ORDER BY bb.created_at)
Пример во вложении.

Кто с такой задачей сталкивался, подскажите плиз...
Все спасибо.
Вложения
Тип файла: xlsx LAG.xlsx (11.8 Кб, 1 просмотров)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.01.2020, 12:48
Ответы с готовыми решениями:

GROUP BY исключая значений с NULL
Доброго времени суток! Прошу подсказать как сделать хитрую выборку. Имеется таблица каталога, с полями: id|title|rat|franchise Поле...

изменить св-во поля на NOT NULL
Есть таблица с данными, нужно изменить св-во поля Sender с NULL На NOT NULL. подсабите пожалуста скриптом. известно, что в таблице...

Сравнение поля с Null
Подскажите, как правильно сравнивать с NULL поле ADOQuery, ругается, что нельзя конвертировать NULL в string if...

2
0 / 0 / 2
Регистрация: 22.04.2015
Сообщений: 70
27.01.2020, 13:46  [ТС]
пока нашел такое решение
SQL
1
COALESCE(bb.dw214, LAG (bb.dw214) OVER(ORDER BY bb.created_at), MAX(bb.dw214) OVER(ORDER BY bb.created_at))
0
1264 / 978 / 384
Регистрация: 02.09.2012
Сообщений: 3,021
27.01.2020, 23:57
Оконные функции не умеют пропускать NULL.
Можно вот так извернуться (использовать специально посчитанное групповое поле)

SQL
1
2
3
4
SELECT f, first_value(xf) OVER (partition BY grp ORDER BY f) FROM (
  SELECT f, xf, SUM(1) FILTER (WHERE xf IS NOT NULL) OVER (ORDER BY f) FROM 
  (VALUES (1,100),(2, 200),(3,NULL),(4,400),(5,500)) AS t(f, xf)
) AS t(f, xf, grp);
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.01.2020, 23:57
Помогаю со студенческими работами здесь

Вывод INT NULL из поля БД
У меня в базе задано значение "int", по умолчанию "null(ноль)", теперь в php я прописываю следующее if (empty($row)) { echo...

Почему значение поля - null?
Объясните пожалуйста, почему в данном случае ссылка имеет значение null. И как правильно вызвать метод Check() в class Bee class Bee ...

Создание поля со значением null
Подскажите, допустим при создании таблицы, в одном из полей этой таблицы оставить не заполненное значение по умолчанию. Т.е. при команде...

Использование IS NULL во вложенных SELECT
Доброго времени суток. Есть запрос такого вида: SELECT `time_entries`.`activity_id` AS `ActivityId`, `issues`.`root_id` AS...

Input lag
Всем привет. Уже на протяжении полгода пытаюсь пофиксить плавающую мышку. И нет, я уверен что дело не в мышке, в том что она умирает....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru