Portál AbcLinuxu, 14. května 2025 01:09

Dotaz: nahodne namiesanie vysledkov z mnoziny udajov

24.3.2014 15:46 adrinko | skóre: 22
nahodne namiesanie vysledkov z mnoziny udajov
Přečteno: 350×
Odpovědět | Admin
Dobry den, v mysql tabulke "vsetky" mam 9 000 zaznamov (tie sa nemenia, teda len obcas pribudne novy). Potreboval by som vsak do tabulky "zmiesane" kazdy den z tych 9 000 namiesat 70 000 zaznamov cez PHP. Premiesavanie by vsak malo byt vzdy nahodne, niektore sa budu opakovat, malo by byt vsak tak nahodne, ze niektore riadky kludne nemusia byt v niektory den namiesane. A kazdy den by mala byt ta zmiesanina ina (v priebehu celeho roka).

Stretli ste sa niekto s niecim takymto, alebo len ja tak vymyslam? :-) V kazdom pripade netusim, ako to takymto sposobom premiesat a kludne aj viackrat premiesat.

Moja predstava je taka, ze si kazdy den o polnoci predpripravim takuto zmiesaninu s datumom noveho dna a potom si uz skript iba vzdy siahne do db pre dalsi zaznam a spatne zaznaci, ze uz bol dany zaznam dnes vybraty. Diky moc za navedenie na cestu.
Nástroje: Začni sledovat (1) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

24.3.2014 16:24 dan
Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
Odpovědět | | Sbalit | Link | Blokovat | Admin
mozno cez ORDER BY RAND()
24.3.2014 16:49 axel
Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
Odpovědět | | Sbalit | Link | Blokovat | Admin
Vygeneruj si 70000 nahodnych cisel z rozsahu 1-9000. Pak si urci deterministicke poradi zdrojovych dat (napr. setridene dle PK) a podle pripravenych indexu je uloz do cilove tabulky. Podminka na unikatnost kazdy den je dost silna - bud budes muset kontrolovat, zda ses nahodou netrefil, vuci vsem dnum, nebo se spolehnes, ze pravdepodobnost takoveho jevu je miziva. Pokud bys chtel kontrolovat, doporucuju spocitat si hash posloupnosti pouzitych indexu a ten si ulozit (pri shode prepocitas, mozna zbytecne, ale porad to bude levnejsi nez porovnavat mnoziny dat).
24.3.2014 19:13 adrinko | skóre: 22
Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
Dan, Axel, dakujem vam obom.
24.3.2014 19:36 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
Předpokládám, že DBE MySQL takže ORDER BY RAND() zafunguje, ale jestli to je M$SQL, tak ne, tam se hodnota RAND() generuje pro dotaz, ne pro řádek.
To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
Tarmaq avatar 25.3.2014 08:55 Tarmaq | skóre: 39
Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
v MSSQL by zafungovalo ORDER BY NEWID(), ale asi to je zbytecne resit, protoze tazatel psal ze to potrebuje pro MySQL
Don't panic!
25.3.2014 09:10 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
Hm, zas nedávám pozor, je to v dotazu napsané…
To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
25.3.2014 13:16 Logik
Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
Jde to jednodušeji - bez generování nějaké tabulky http://stackoverflow.com/questions/6541644/selecting-random-rows-with-mysql

SET @r := (SELECT ROUND(RAND() * (SELECT COUNT(*) FROM mytable)));
SET @sql := CONCAT('SELECT * FROM mytable LIMIT 1 OFFSET ', @r);
PREPARE stmt1 FROM @sql;
EXECUTE stmt1;

Popř. lze samozřejmě dotaz složit i na klientovi, todle je čistě MySQL řešení...

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.