Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: порядок выборки
Форумы портала PHP.SU » » Вопросы новичков » порядок выборки

Страниц (1): [1]
 

1. jonston - 25 Января, 2014 - 00:27:04 - перейти к сообщению
Здравствуйте.Есть поле (int) в таблице по которой осуществляется сортировка записей.Как сделать что бы скрип выбрал все от 1 по возрастанию, а потом уже нули?
2. caballero - 25 Января, 2014 - 01:47:15 - перейти к сообщению
например два запроса через union
3. Мелкий - 25 Января, 2014 - 08:16:38 - перейти к сообщению

По старому обыкновению, мог напутать ASC/DESC
4. jonston - 25 Января, 2014 - 18:21:07 - перейти к сообщению
Мелкий пишет:
По старому обыкновению, мог напутать ASC/DESC

Не получается.Все равно нули первые.
(Добавление)
Мелкий пишет:
По старому обыкновению, мог напутать ASC/DESC


помогло
CODE (SQL):
скопировать код в буфер обмена
  1. ORDER BY  int = 0, int ASC
.Объясните пожалуйста как компилятор обрабатывает сей запрос.А то что то не доходит.
5. green_man - 25 Января, 2014 - 18:34:32 - перейти к сообщению
Зачем именно такой порядок?
Неудобно цикл делать?Улыбка
6. jonston - 25 Января, 2014 - 18:47:20 - перейти к сообщению
green_man пишет:
Зачем именно такой порядок?
Неудобно цикл делать?Улыбка


Ну смотри если тебе интересно.Есть города и регионы (все в одной таблице.Знаю что не удобно но переделывать не вариант).У них есть поле порядок сортировки.Для удобства использования нужно выводить Республика Адыгея, Майкоп и так далее.То есть Регион и столица региона.Контентщик отсортировал все регионы и города в порядке возрастания по алфавиту.То есть Адыгея идет первой по алфавиту и потом должен идти региональный центр - Майкоп.Соответственно 1 и 2.И так далее.Но остались еще города у которых по умолчанию стоит ноль (не региональные центры но нужные крупные города).Если выводить все по порядку, то нулевые будут первыми.А в приоритете должны быть регионы и их столицы.Не знаю доходчиво ли описал, но как смог.
7. green_man - 25 Января, 2014 - 18:58:22 - перейти к сообщению
Первое что приходит на ум это конечно union, а так подумать надо.
8. jonston - 25 Января, 2014 - 20:06:51 - перейти к сообщению
green_man пишет:
Первое что приходит на ум это конечно union, а так подумать надо.
Решил уже.Мелкий подсказал почти правильный вариант.Только вмеcто > z я поставил =.
9. Мелкий - 25 Января, 2014 - 20:21:14 - перейти к сообщению
jonston пишет:
.Объясните пожалуйста как компилятор обрабатывает сей запрос.А то что то не доходит.

Как делается сортировка по двум полям знаете?
Тут то же самое, только одно поле вы непосредственно в результате не видите, оно на лету считается.
Сделайте
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT int, int=0 AS firstsort, int AS secondsort FROM `table` ORDER BY firstsort, secondsort ASC

Увидите, что сперва отсортировано по столбцу, содержащему только 0 или 1 (результат сравнения int=0), а строки, имеющие одинаковые значения по первому столбцу - уже выполнена сортировка по значению int
10. jonston - 25 Января, 2014 - 20:41:32 - перейти к сообщению
Мелкий пишет:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT int, int=0 AS firstsort, int AS secondsort FROM `table` ORDER BY firstsort, secondsort ASC

Увидите, что сперва отсортировано по столбцу, содержащему только 0 или 1 (результат сравнения int=0), а строки, имеющие одинаковые значения по первому столбцу - уже выполнена сортировка по значению int

Примерно понял.Только почему в запросе
CODE (SQL):
скопировать код в буфер обмена
  1. ORDER BY int = 0, int ASC

Выводятся сначала все от 1 по возрастающей, а потом уже нули.Ведь по логике должные нули, а потом все по возрастающей?
11. Мелкий - 25 Января, 2014 - 20:43:34 - перейти к сообщению
Ну я и говорю, постоянно путаю направления сортировок...
12. jonston - 25 Января, 2014 - 20:52:20 - перейти к сообщению
Мелкий пишет:
Ну я и говорю, постоянно путаю направления сортировок...

Не, не, не.Смотри.Первое интерпретатор понимает как отобрать все нулевые значения по возрастанию (то есть нули), а потом уже int asc (остальные от 1+...)
13. EuGen - 26 Января, 2014 - 11:17:51 - перейти к сообщению
Потому что он сортирует по значению выражения "int=0". Это значение будет равно 1, если int в самом деле 0 (ведь 0=0) или 0, если int не равен 0 (поскольку всё, что угодно, кроме 0, не равно 0). Поэтому сначала будут идти строки, у которых значение выражения "int=0" равно 0 (то есть всё, где int не 0), затем те, у которых значение выражения "int=0" равно 1 (то есть все те, у которых int=0)
14. jonston - 26 Января, 2014 - 14:52:57 - перейти к сообщению
EuGen пишет:
Потому что он сортирует по значению выражения "int=0". Это значение будет равно 1, если int в самом деле 0 (ведь 0=0) или 0, если int не равен 0 (поскольку всё, что угодно, кроме 0, не равно 0). Поэтому сначала будут идти строки, у которых значение выражения "int=0" равно 0 (то есть всё, где int не 0), затем те, у которых значение выражения "int=0" равно 1 (то есть все те, у которых int=0)

Да спасибо.Я понял попрактиковавшись.То есть он создает как бы новое поле в памяти и присваивает ему значение выражения int = 0 и потом сортирует уже в соответствии с ним.

 

Powered by ExBB FM 1.0 RC1