Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.09.19;
Скачать: CL | DM;

Вниз

Ротация   Найти похожие ветки 

 
Вовчик   (2004-08-24 03:24) [0]

Нужно сделать следующее:
есть 10 записей, у которых два поля: "имя" и "приоритет"... Например, вот 10 записей

имя - приоритет
1 - 1
2 - 2
3 - 3
4 - 4
5 - 4
6 - 4
7 - 4
8 - 4
9 - 4
10 - 4

При первом выполнении запроса должно получиться так:
1
2
3
4
5
6
7
8
9
10
т.е. у кого приоритет больше четырех, выстраиваются согласно приоритету, а остальные "как попало" :)

при втором вызове должно получиться следующее:
1
2
3
5
6
7
8
9
10
4

т.е. с приоритетом больше четырех остались на своих местах, а те которые без приоритета поменялись местами: тот, кто был вверху, оказался в самом внизу, остальные поднялись наверх на одно место... что-то типа стека....

Как это реализовать?


 
elected   (2004-08-24 03:59) [1]

Слышь че =-)))
Объясни толком что нужно! А я не телепат ! =-)


 
vovchik   (2004-08-24 04:50) [2]

В случае со стеком (Последний пришёл - первый ушёл) там участвуют все элементы а не отдельная часть набора данных. Ты сначала ограничь то что тебе надо, а потом уже меняй элементы


 
Nikolay M. ©   (2004-08-24 09:54) [3]

Вот это череззабоногузадерищенскозапупинская задачка! :)
Мало того, что средствами SQL эта задача практически нереализуема, так она еще и поставлена некорректно:

1)

> т.е. с приоритетом больше четырех остались на своих местах,
> а те которые без приоритета поменялись местами

В примере они ВСЕ(!) с приоритетом.

2)
Как можно сначала отсортировать

> остальные "как попало"

а потом из этого "как попало" (что попало? куда попало?) сделать

> что-то типа стека

Короче: не церебрируй людям мОзги :)
Делай все на клиенте.


 
Вовчик   (2004-08-24 11:16) [4]

Короче: обеспечивается равноправие записей, т.е. каждая из них когда-то окажется в самом верху... если она оказалась наверху, то в следующий раз окажется внизу, вторая запись станет первой, третья - второй и т.д.  
Помимо этого есть три записи с приоритетом, которые будут ВСЕГДА распологаться на первых трех позициях...

Если что-то объяснено непонятно, извиняйте... Постанова задачи совсем идиотская... но заказчики требуют именно такого...


 
KSergey ©   (2004-08-24 11:22) [5]

Ну реализовать можно, вероятно, кучей способов...
Можно завести еще поле, в котором сохранять реальную нумерацию для последней выборки (или заполнить при первой), после чего для записей с одинаковым приоритетом это поле и "ротировать". Или просто к значению первой из них (из записей с одним приоритетом) (после выборки) прибавлять что-нибудь...



Страницы: 1 вся ветка

Текущий архив: 2004.09.19;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.05 c
8-1088269863
Marser
2004-06-26 21:11
2004.09.19
Панель управления. Свойства:Звук


4-1091777599
Ricko
2004-08-06 11:33
2004.09.19
SMS и PDU


1-1094035424
Wolfram
2004-09-01 14:43
2004.09.19
int в минуты?


14-1092885095
КаПиБаРа
2004-08-19 07:11
2004.09.19
Тестирование ПО под разными OS


1-1094267367
Aono4ever
2004-09-04 07:09
2004.09.19
Переход к фиксированному значению через текущее