RE: order by ASC

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



http://lmgtfy.com/?q=mysql+order+by+slow
 
it's notoriously slow to use ORDER BY with large tables. Mainly b/c mySQL
has to use a hash/temp table to re-sort AFAIK.
 
I wasn't thinking of sorting the whole set, only the list of numbers as the
OP only talked about sorting a single column...
 
>>> rollnumber is a varchar(50). I need it to be a text field. ASC does 
>>> not order the way I want.
>>>
>>> 1000
>>> 1001
>>> 998
>>> 999
>>>
>>> I want it to order like this:
>>>
>>> 998
>>> 999
>>> 1000
>>> 1001


  _____  

From: Ashley Sheridan [mailto:ash@xxxxxxxxxxxxxxxxxxxx] 
Sent: Tuesday, January 19, 2010 4:40 PM
To: Daevid Vincent
Cc: 'PHP-General'
Subject: RE:  order by ASC


On Tue, 2010-01-19 at 16:16 -0800, Daevid Vincent wrote: 

http://www.webdeveloper.com/forum/showthread.php?t=101174



You could do it like this too...



ORDER BY `rollnumber` + 0 ASC 



And if you just got the data out in mysql (no ORDER BY -- which can be slow

in mysql), you could use PHP's sort as well...



http://php.net/manual/en/function.natsort.php



> -----Original Message-----

> From: Robert Cummings [mailto:robert@xxxxxxxxxxxxx] 

> Sent: Saturday, January 16, 2010 9:37 PM

> To: John Taylor-Johnston

> Cc: PHP-General

> Subject: Re:  order by ASC

> 

> John Taylor-Johnston wrote:

> > Did some googling. This worked:

> > ORDER BY CAST(`rollnumber` AS SIGNED)

> > 

> > What is the difference? My problem in the meanwhile must be 

> my version 

> > of MySQL?

> 

> You could have skipped quotes altogether. The difference is 

> that you are 

> referencing a field name, not a string value.

> 

> Cheers,

> Rob.

> -- 

> http://www.interjinn.com

> Application and Templating Framework for PHP

> 

> -- 

> PHP General Mailing List (http://www.php.net/)

> To unsubscribe, visit: http://www.php.net/unsub.php

> 






I've always found that ordering is much faster in MySQL than PHP. You use
quite a lot of memory sorting in PHP as well, as you first have to load the
whole result set into an array, which is additional to any memory used in
the result set by PHP and MySQL anyway.


Thanks,
Ash
http://www.ashleysheridan.co.uk


	


[Index of Archives]     [PHP Home]     [Apache Users]     [PHP on Windows]     [Kernel Newbies]     [PHP Install]     [PHP Classes]     [Pear]     [Postgresql]     [Postgresql PHP]     [PHP on Windows]     [PHP Database Programming]     [PHP SOAP]

  Powered by Linux