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

Вниз

Знатокам SQL   Найти похожие ветки 

 
Turalyon   (2001-12-17 10:12) [0]

Привет всем.
Есть задача - необходимо чтобы в результате запроса записи были в случайном порядке (типа экзамен). Есть ли какой нить способ сделать их случайными прямо в запросе?
Я придумал способ как это сделать "в ручную" создаю структуру, в которй храню ключи от результата SQL запроса, потом их "перемешиваю" и выдаю по одному... но это как мне кажется через з..цу может есть способ попроще???


 
Alexandr   (2001-12-17 10:26) [1]

на SQL видимо никак
только на клиенте ручками.
и в слечае парадокса это нормально.


 
gek   (2001-12-17 10:30) [2]

Я делал так сначала генерил числа случайные ну а потом запрос делал типа

SetCif:set of 1..255;
SetCif:=[];
k:word;
CountProhod:word;
CountProhod:=0;
repeat
k:=random(200);
if(not (k in SetCif))and(k <> 0) then
begin
SetCif:=SetCif +[k];
inc(CountProhod);
end;
until CountProhod = 10;//кол-во вопросов

select * from mytable where id in SetCif все нормально работает


 
Turalyon   (2001-12-17 10:41) [3]

2gek
А разве в результате выполнения запроса оно не выберет все по порядку следования в физичексой таблице? Мне просто не совсем понятно как работает оператор in. То есть я понимаю как он работает, только не понятно, в каком порядке он будет выбирать записи из списка SetCif.


 
gek   (2001-12-17 10:54) [4]

Когда я все это дело делал у меня такой вопрос не стоял. Честно говоря
не могу просветить. Для меня было главное получить случайные записи.
Но вот че на ум приходит - можно таким же образом отфильтровать таблицу не прибегая к SQL запросу.
Да если тебе надо как то упорядочить записи используй ORDER BY для SQL
ну и индексы для обычной таблицы


 
Turalyon   (2001-12-17 11:08) [5]

Мне наоборот не надо их упорядочивать, а перемешать надо :)
Я попробовал сейчас в SQLExplorer -е все работает, причем в результате запроса выдается сначала та запись, которая стоит первая в списке, потом след. и т.д. так что если они рандомные, то все ок. СПАСИБО БОЛЬШОЕ!!!!



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

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

Наверх




Память: 0.48 MB
Время: 0.009 c
14-52660
zvon
2001-11-23 07:03
2002.01.17
как программно отправить файл на мыло


1-52600
Romul
2001-12-29 17:10
2002.01.17
Вопрос по TThread


3-52510
dron1
2001-12-15 18:38
2002.01.17
master/detail


3-52505
Кнопка
2001-12-09 15:07
2002.01.17
Поиск в базе


6-52630
z0ne
2001-10-19 02:18
2002.01.17
server sharedirname --->>> d: dir subdirwhatshared