![]() |
![]() |
![]() |
|||||
![]() |
![]() |
![]() |
![]() |
![]() |
|||
| Welcome
to Tech Support Forum home to more then 136,000 problems solved. Issues
have included: Spyware, Malware, Virus Issues, Windows, Microsoft,
Linux, Networking, Security, Hardware, and Gaming Getting your
problem solved is as easy as: 1. Registering for a free account 2. Asking your question 3. Receiving an answer Registered members: * See fewer ads. * And much more..
|
| Want to know how to post a question? click here | Having problems with spyware and pop-ups? First Steps |
|
|||||||
| Web Design & Programming Discussion of web design, and server-side & client-side scripting |
![]() |
|
|
LinkBack | Thread Tools |
|
|
#1 (permalink) |
|
Registered User
Join Date: Jan 2007
Posts: 108
OS: window XP
|
PHP sorting problem using SQL "ORDER BY" statement
i have a sorting problem in php using the SQL command "ORDER BY".
----------------- For example: i want to sort this number descending: 30, 4, 50, 200. so in actual case we should get: 200 , 50, 30 , 4. But what i get when using the ORDER BY statement is: 50, 4, 30, 200 ------------------- After look a while at the incorrect result, i think the problem is because it sort using the first digit of the number. Anyone know how to solve this problem? Thank in advance. |
|
|
|
| Important Information |
|
Join the #1 Tech Support Forum Today - It's Totally Free!
TechSupportForum.com is a leading support website for your computer needs. We offer free, friendly and personalized computer support. Why pay to have your computer fixed when you can do it for free. Join TechSupportforum.com Today - Click Here |
|
|
#3 (permalink) |
|
Registered User
Join Date: Jan 2007
Posts: 108
OS: window XP
|
Re: PHP sorting problem using SQL "ORDER BY" statement
Just for your information, i already tried "ORDER BY $variable DESC" ?
Thank for your reply redcore. ------------------------------------- I have found the solution. I just realize that i am using char datatype for the column. so i use this solution. ------------------------------------------- To sort character column foo as an integer ORDER BY foo + 0 DESC ORDER BY CAST(foo AS UNSIGNED) What happens when you add 0 to foo is that mysql is forced to convert foo into an integer. After that, it is sorted as an integer. The same happens when you explicitly cast foo to an integer using CAST(). "Cast" means "Change from one type to another". The original problem is that your numbers were being sorted as strings, which is why it looked at the first character first, then second, and so on. |
|
|
|
|
|
#4 (permalink) |
|
TSF Enthusiast
Join Date: Nov 2004
Posts: 555
OS: Windows XP Pro & Windows Vista Ultimate browsing the web with FF, Opera, Safari and IE.
|
Re: PHP sorting problem using SQL "ORDER BY" statement
@ peterjcs: thank you for posting the answer to your problem! It might be helpfull for someone with (more or less) the same problem.
__________________
KoosHopeloos, straight to you from .nl via the world wide web! ![]() |
|
|
|
![]() |
| Thread Tools | |
|
|