Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011
Помог: 3 раз(а)
Здравствуйте.Есть поле (int) в таблице по которой осуществляется сортировка записей.Как сделать что бы скрип выбрал все от 1 по возрастанию, а потом уже нули?
----- $i = 0;
$i = $i++ + ++$i; ?
caballero
Отправлено: 25 Января, 2014 - 01:47:15
Активный участник
Покинул форум
Сообщений всего: 5998
Дата рег-ции: Сент. 2011 Откуда: Харьков
Покинул форум
Сообщений всего: 55
Дата рег-ции: Июль 2012
Помог: 6 раз(а)
Зачем именно такой порядок?
Неудобно цикл делать?
jonston
Отправлено: 25 Января, 2014 - 18:47:20
Посетитель
Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011
Помог: 3 раз(а)
green_man пишет:
Зачем именно такой порядок?
Неудобно цикл делать?
Ну смотри если тебе интересно.Есть города и регионы (все в одной таблице.Знаю что не удобно но переделывать не вариант).У них есть поле порядок сортировки.Для удобства использования нужно выводить Республика Адыгея, Майкоп и так далее.То есть Регион и столица региона.Контентщик отсортировал все регионы и города в порядке возрастания по алфавиту.То есть Адыгея идет первой по алфавиту и потом должен идти региональный центр - Майкоп.Соответственно 1 и 2.И так далее.Но остались еще города у которых по умолчанию стоит ноль (не региональные центры но нужные крупные города).Если выводить все по порядку, то нулевые будут первыми.А в приоритете должны быть регионы и их столицы.Не знаю доходчиво ли описал, но как смог.
----- $i = 0;
$i = $i++ + ++$i; ?
green_man
Отправлено: 25 Января, 2014 - 18:58:22
Новичок
Покинул форум
Сообщений всего: 55
Дата рег-ции: Июль 2012
Помог: 6 раз(а)
Первое что приходит на ум это конечно union, а так подумать надо.
jonston
Отправлено: 25 Января, 2014 - 20:06:51
Посетитель
Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011
Помог: 3 раз(а)
green_man пишет:
Первое что приходит на ум это конечно union, а так подумать надо.
Решил уже.Мелкий подсказал почти правильный вариант.Только вмеcто > z я поставил =.
----- $i = 0;
$i = $i++ + ++$i; ?
Мелкий
Отправлено: 25 Января, 2014 - 20:21:14
Активный участник
Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009 Откуда: Россия, Санкт-Петербург
Помог: 618 раз(а)
jonston пишет:
.Объясните пожалуйста как компилятор обрабатывает сей запрос.А то что то не доходит.
Как делается сортировка по двум полям знаете?
Тут то же самое, только одно поле вы непосредственно в результате не видите, оно на лету считается.
Сделайте
SELECT int, int=0 AS firstsort, int AS secondsort FROM`table`ORDERBY firstsort, secondsort ASC
Увидите, что сперва отсортировано по столбцу, содержащему только 0 или 1 (результат сравнения int=0), а строки, имеющие одинаковые значения по первому столбцу - уже выполнена сортировка по значению int
----- PostgreSQL DBA
jonston
Отправлено: 25 Января, 2014 - 20:41:32
Посетитель
Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011
SELECT int, int=0 AS firstsort, int AS secondsort FROM`table`ORDERBY firstsort, secondsort ASC
Увидите, что сперва отсортировано по столбцу, содержащему только 0 или 1 (результат сравнения int=0), а строки, имеющие одинаковые значения по первому столбцу - уже выполнена сортировка по значению int
Выводятся сначала все от 1 по возрастающей, а потом уже нули.Ведь по логике должные нули, а потом все по возрастающей?
----- $i = 0;
$i = $i++ + ++$i; ?
Мелкий
Отправлено: 25 Января, 2014 - 20:43:34
Активный участник
Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009 Откуда: Россия, Санкт-Петербург
Помог: 618 раз(а)
Ну я и говорю, постоянно путаю направления сортировок...
----- PostgreSQL DBA
jonston
Отправлено: 25 Января, 2014 - 20:52:20
Посетитель
Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011
Помог: 3 раз(а)
Мелкий пишет:
Ну я и говорю, постоянно путаю направления сортировок...
Не, не, не.Смотри.Первое интерпретатор понимает как отобрать все нулевые значения по возрастанию (то есть нули), а потом уже int asc (остальные от 1+...)
----- $i = 0;
$i = $i++ + ++$i; ?
EuGen
Отправлено: 26 Января, 2014 - 11:17:51
Профессионал
Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007 Откуда: Berlin
Помог: 707 раз(а)
Потому что он сортирует по значению выражения "int=0". Это значение будет равно 1, если int в самом деле 0 (ведь 0=0) или 0, если int не равен 0 (поскольку всё, что угодно, кроме 0, не равно 0). Поэтому сначала будут идти строки, у которых значение выражения "int=0" равно 0 (то есть всё, где int не 0), затем те, у которых значение выражения "int=0" равно 1 (то есть все те, у которых int=0)
----- Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
jonston
Отправлено: 26 Января, 2014 - 14:52:57
Посетитель
Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011
Помог: 3 раз(а)
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 и потом сортирует уже в соответствии с ним.
Все гости форума могут просматривать этот раздел. Только зарегистрированные пользователи могут создавать новые темы в этом разделе. Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.