Náhodné řádky z databáze – MySQL – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama
Reklama

Náhodné řádky z databáze – MySQL – Fórum – Programujte.comNáhodné řádky z databáze – MySQL – Fórum – Programujte.com

 

Toto vlákno bylo označeno za vyřešené.
Hledá se programátor! Plat 1 800 € + bonusy (firma Boxmol.com)
Forest0
Stálý člen
7. 10. 2013   #1
-
0
-

Zdravím,

poradil by mi prosím někdo, jak z tabulky, o 100 řádcích, vytáhnout náhodně 50?

Našel jsem něco jako:

ORDER BY RAND()

A dočetl jsem se, že pro větší množství řádků, je to "zlo". Díky předem.

Nahlásit jako SPAM
IP: 92.62.230.–
Reklama
Reklama
peter
~ Anonymní uživatel
2551 příspěvků
8. 10. 2013   #2
-
0
-

Asi 5-10 min googlovani. Jak dlouho to trvalo tobe?
http://diskuse.jakpsatweb.cz/?…
http://diskuse.jakpsatweb.cz/?…

SELECT * FROM jmena ORDER BY RAND() LIMIT 3
---
SELECT .... WHERE id IN (123,321,456,654,789,987, ... ,11) LIMIT 3
Vygenerovat 30 náhodných čísel trvá chvíli (v porovnání s 10k). A nemusí se to podle nich řadit. 
---
Náhodné číslo ve zvoleném intervalu ti vrátí funkce rand().
Náhodný výběr z explicitně daných hodnot pak nejlépe pomocí array_rand(). 
---
ORDER BY RAND(NOW());
SELECT * FROM foo ORDER BY RAND (NOW ()) LIMIT 1;
---
mohu mít otázku? v čem je lepší vložený dotaz?
select * from fotky where id in (select id from fotky order by rand() limit 1)
vs.
select adresa, popis from fotky order by rand() limit 1
-> http://dev.mysql.com/…ization.html
---
Zkusil jsem to na tabulce, co má lehce přes milion záznamů, a rozdíl tam je...
select * from protokoly_data_pol p order by rand() limit 10
--15 s
select p.* from protokoly_data_pol p, (select p2.vid, p2.pol_id from protokoly_data_pol p2 order by rand() limit 10) p3 where p.vid=p3.vid and p.pol_id=p3.pol_id;
--1.5 s
Podle explain, druhý opravdu použije primární index a řadí hodnoty z něho. 
Nahlásit jako SPAM
IP: 193.84.207.–
Forest0
Stálý člen
8. 10. 2013   #3
-
0
-

#2 peter
Pokud sis nevšiml, tak jsem psal, že jsem tu funkci našel, ale ty sis to přečetl jen do půlky ;-)

Nahlásit jako SPAM
IP: 92.62.230.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 7 hostů

Podobná vlákna

Nové řádky — založil HoHo

řádky ruleta DELPHI 7 — založil lukas

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032016 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý