Am 26.10.2011 05:14, schrieb mos:
>> > It is not "braindead". You told MySQL to sort by rand() which is a 
>> > non-indexed column.
>> > It needs to assign a value to each row of the result set (all ids of the 
>> > table) and sort
>> > it to get the lowest random number. This is very inefficient for large 
>> > tables.
>>
>> but there is mo need to do this with the whole table
>> if the only requested field is the primary key
> 
> Sure but if the table has 100 million rows and you want 1 random id, that 
> means sorting 100 million id's from the
> index to disk. This is still grossly inefficient. It may work fine on tables 
> with a couple thousand rows, but not
> for million row tables. That's why the two methods I suggested don't use 
> sorting.

this is not the topic
the topic is "order by rand()" works braindead
all other things are workarounds

and it still matters on small tables with only 512KB if mysqld
makes on each query a 512KB temp-file or not - have fun under
concurrent load even with small tables!

only the auto-ids are tiny data and nothing more is requested here
as result and no reason to copy the whole table with all fields around


Attachment: signature.asc
Description: OpenPGP digital signature

Reply via email to