-
Data: 2012-04-24 11:11:21
Temat: Re: losowy rekord w sqlu
Od: zażółcony <r...@c...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2012-04-23 18:49, M.M. pisze:
> zażółcony<r...@c...pl> napisał(a):
>
>> W dniu 2012-04-21 16:08, M.M. pisze:
>>> Hey
>>>
>>> Moje pytanie jest proste. Jak efektywnie wybrać losowy
>>> rekord (ewentualnie kilka losowych) dużej tabeli w sqlu?
>>>
>>> Sztuczki tego typu:
>>> SELECT * FROM table ORDER BY rand LIMIT kilka
>>> zdaje się że przeglądają całą tabelę, a to jest niedopuszczalne.
>>>
>>> Pozdrawiam
>>
>> Taki pomysł "z czapki":
>> Dodaj sobie dodatkowe pole RND, z góry wypełnij je wartościami
>> losowymi typu double z przedziału<0.0-1.0)
>> Jak przewidujesz bardzo dużo rekordów - być może warto rozważyć
>> dwa double
>>
>> Zakładasz indeks.
>>
>> Potem trzaskasz zapytania w rodzaju
>> select limit 1 where RND<=random()
>
> Nie zadziała. Gdy rekord z małą wartością pola RND będzie się
A fakt, kopnąłem sie ... Pierwotnie
była relacja w drugą stronę, sorry:
select limit 1 where RND>=random()
miał być jeszcze
order by RND
Wtedy idzie.
> pojawiał pierwszy w kolejności przeglądania to on zdecydowanie częściej
> będzie się wyświetlał. Rekordowi pobranemu trzeba nadać nową losową
> wartość:
>
> Może tak:
>
> rnd = rand();
> rekord = MIN( T.rnd );
> rekord.rnd = rand();
>
> 1) Nie powinno być kłopotów przy złączeniach
> 2) Można założyć index na T.rnd
> 3) Nie ma problemów z usuwaniem i "dziurami"
> 4) Rozkład... właśnie nie mam pewności jaki jest rozkład.
Rozkład jest ok, jak generator losowy jest ok :)
Następne wpisy z tego wątku
Najnowsze wątki z tej grupy
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
Najnowsze wątki
- 2024-09-14 Canon 550D
- 2024-09-14 Odcinkowy Pomiar Prędkości. NIELEGALNY w Polsce!!! Nie daj SIĘ!
- 2024-09-14 Warszawa => Menadżer Okręgu <=
- 2024-09-14 Łódź => Spedytor Międzynarodowy <=
- 2024-09-14 Warszawa => Kierownik Działu Spedycji Międzynarodowej <=
- 2024-09-14 Warszawa => Technical Leader (Java Background) <=
- 2024-09-14 Gdynia => Spedytor Międzynarodowy <=
- 2024-09-14 k.o.mendant
- 2024-09-12 Z cyklu POJEBANA UE: samochody elektryczne nie mogą być tanie i dobre
- 2024-09-13 dodanie karty graf zawiesza komp
- 2024-09-13 Sezon grzewczy kurła
- 2024-09-13 Warszawa => Spedytor Międzynarodowy <=
- 2024-09-13 Warszawa => Mid Account Manager <=
- 2024-09-13 Warszawa => QA Engineer <=
- 2024-09-13 Białystok => Frontend Developer (Angular area) <=