Форум программистов, компьютерный форум, киберфорум
Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
1 / 1 / 1
Регистрация: 29.06.2012
Сообщений: 58

Можно ли получить такой результат одним запросам

01.01.2018, 18:53. Показов 682. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Можно ли с такой таблицы (SQlite):
SQL
1
2
3
4
5
6
fio           price   dt
Петров    4500   2017-11-01 13:20:21
Сидоров  3000   2017-11-02 08:09:08
Сидоров  1000   2017-11-09 08:11:34
Сидоров  2000   2017-11-20 16:17:12
Петров    1000   2017-12-01 08:32:49
Получить вот такой результат
SQL
1
2
3
4
Ожидание:
Петров     2017-11-01 13:20:21   2017-11-01 13:20:21
Сидоров   2017-11-02 08:09:08   2017-11-20 16:17:12
Петров     2017-12-01 08:32:49   2017-12-01 08:32:49
Вот такой запрос не подходит, т.к. он объединяет все fio и потом только сортирует по дате:
SQL
1
2
3
4
5
6
7
8
9
SELECT 
  fio,
  MIN(dt) AS START,
  MAX(dt) AS stop,
FROM
  RBCTNCSCNHNH
GROUP BY
  fio
ORDER BY START ASC
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.01.2018, 18:53
Ответы с готовыми решениями:

Можно ли продвинуть сайт по запросам в такой ситуации
Есть сайт, который нужно продвинуть по по трем запросам. Продвигать собираюсь своими же сайтами (5 штук), сделанными на народе по точно...

Как получить такой результат? Результат на Картинке
Как сделать так чтобы лого было по середине, а текст по бокам....все как на картинке? Что написать в HTML и CSS? Заранее спасибо)

Запишите латинские буквы в такой последовательности, в которой можно получить фрагмент Паскаль-программы
Дан набор операторов: Запишите латинские буквы в такой последовательности, в которой можно получить фрагмент Паскаль-программы,...

8
5961 / 4537 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
02.01.2018, 07:36
Цитата Сообщение от timka23 Посмотреть сообщение
Получить вот такой результат
нельзя

Сидорова ты без проблем группируешь, а Петрова уже не хочешь
0
1 / 1 / 1
Регистрация: 29.06.2012
Сообщений: 58
02.01.2018, 10:30  [ТС]
Так мне не группировка нужна, а периоды оплаты, последовательные.
0
5961 / 4537 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
02.01.2018, 11:58
что тебе нужно получить известно только тебе
задание ты не написал
0
765 / 666 / 194
Регистрация: 24.11.2015
Сообщений: 2,163
04.01.2018, 15:17
Цитата Сообщение от qwertehok Посмотреть сообщение
нельзя
Можно. Следующий запрос даст нужный результат. Только задания, по-прежнему, нет, поэтому не уверен, что ответ правильный
SQL
1
2
3
4
5
6
7
8
9
SELECT 
 fio,
 MIN(dt) AS START,
 MAX(dt) AS stop,
FROM
 RBCTNCSCNHNH
GROUP BY
 fio, trunc(dt,'mm')
ORDER BY START ASC
0
1 / 1 / 1
Регистрация: 29.06.2012
Сообщений: 58
06.01.2018, 23:47  [ТС]
Нет, данный запрос работает не так как нужно. Необходимо выводить диапазон времени оплаты по порядку, периодами, т.е. не группировать все по фамилии и показывать время появления и время окончания, а показывать периоды если они есть до появления нового человека. Я думал на приведенном примере будет все понятно.

Пока решил добавлять еще один столбец в который вношу уникальный номер операции который изменяется если предыдущие fio отличаются и затем все группирую по последнему столбцу.
SQL
1
2
3
4
5
Петров    4500   2017-11-01 13:20:21   1
Сидоров  3000   2017-11-02 08:09:08   2
Сидоров  1000   2017-11-09 08:11:34   2
Сидоров  2000   2017-11-20 16:17:12   2
Петров    1000   2017-12-01 08:32:49   3
0
765 / 666 / 194
Регистрация: 24.11.2015
Сообщений: 2,163
09.01.2018, 10:31
Цитата Сообщение от timka23 Посмотреть сообщение
показывать периоды если они есть до появления нового человека
Что такое "периоды"? Почему Петров - новый человек? Он уже старый.
Цитата Сообщение от timka23 Посмотреть сообщение
вношу уникальный номер операции который изменяется если предыдущие fio отличаются
Не предыдущие, а fio из предыдущей строки.
Можно сделать запрос, но есть проблема. В Oracle нет номера строки в таблице, есть только порядок вывода строк в запросе. Поэтому непонятно, как сортировать, какую строку считать предыдущей. Допустим, сегодня строки выходят в следующем порядке
Цитата Сообщение от timka23 Посмотреть сообщение
fio price dt
1 Петров 4500 2017-11-01 13:20:21
2 Сидоров 3000 2017-11-02 08:09:08
3 Сидоров 1000 2017-11-09 08:11:34
4 Сидоров 2000 2017-11-20 16:17:12
5 Петров 1000 2017-12-01 08:32:49
Но это не означает, что через несколько дней (после каких-то вставок или корректировок таблицы) строки не вернутся в следующем порядке
fio price dt
1 Сидоров 3000 2017-11-02 08:09:08
2 Петров 4500 2017-11-01 13:20:21
3 Сидоров 1000 2017-11-09 08:11:34
4 Петров 1000 2017-12-01 08:32:49
5 Сидоров 2000 2017-11-20 16:17:12
При таком порядке следования строк результат изменится.
Значит нужно какое-то поле, по которому строки будут однозначно сортироваться всегда в одном и том же порядке. Таким полем может быть, например, та же дата. Если считать, что строки отсортированы по дате, причем повторяющихся дат нет, то можно написать следующее
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
SELECT 
 fio,
 MIN(dt) AS START,
 MAX(dt) AS stop
FROM (
SELECT 
  fio, price, dt, 
  SUM(fl) OVER (ORDER BY dt) ss
FROM (
SELECT 
  fio, price, dt, 
  CASE WHEN fio=lag(fio,1) OVER (ORDER BY dt) THEN 0 ELSE 1 END fl
FROM
 RBCTNCSCNHNH
))
GROUP BY fio, ss
0
1 / 1 / 1
Регистрация: 29.06.2012
Сообщений: 58
09.01.2018, 23:05  [ТС]
База данных SQLite.
При выполнении запроса выдает ошибку первую скобку: FROM (
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
SELECT 
 fio,
 MIN(dt) AS START,
 MAX(dt) AS stop
FROM (
SELECT 
  fio, price, dt, 
  SUM(fl) OVER (ORDER BY dt) ss
FROM (
SELECT 
  fio, price, dt, 
  CASE WHEN fio=lag(fio,1) OVER (ORDER BY dt) THEN 0 ELSE 1 END fl
FROM
 RBCTNCSCNHNH
))
GROUP BY fio, ss
0
765 / 666 / 194
Регистрация: 24.11.2015
Сообщений: 2,163
10.01.2018, 09:54
Цитата Сообщение от timka23 Посмотреть сообщение
База данных SQLite.
Прошу прощения, но я писал для Oracle.
Я думаю, что проблема в написании аналитических функций. Для Oracle селект работает. А как их напиать на SQLite и есть ли они там в принципе, увы, понятия не имею
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.01.2018, 09:54
Помогаю со студенческими работами здесь

Можно ли получить в label1 результат из dll переменной res
Допустим есть dll ка и прога в которой она добавленна. Можно ли получить в label1 результат из dll переменной res. dll using System; ...

AES известна исходная строка и результат, можно получить ключ?
Здравствуйте. Есть исходная строка 128бит и зашифрованная. Известно, что ключ 128бит. Есть способ вычислить ключ, кроме брута?

Как сделать POST по HTTPS из ASP(и чтобы можно было результат получить)?
Как сделать POST по HTTPS из ASP(и чтобы можно было результат получить)? Горю, помогите..

Число 125874 и результат умножения его на 2 — 251748 можно получить друг из друга перестановкой цифр
Задача 2 Число 125874 и результат умножения его на 2 — 251748 можно получить друг из друга перестановкой цифр. Найдите наименьшее...

Можно ли найти статистику по запросам
Можно ли где-то найти статистику пользовательских запросов к поисковой системе? Ну например вводишь ключевую фразу "продажа...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
YAFU@home — распределённые вычисления для математики. На CPU
Programma_Boinc 20.01.2026
YAFU@home — распределённые вычисления для математики. На CPU YAFU@home — это BOINC-проект, который занимается факторизацией больших чисел и исследованием aliquot-последовательностей. Звучит. . .
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru