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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: порядок выборки

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Без описания
jonston
Отправлено: 25 Января, 2014 - 00:27:04
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




Здравствуйте.Есть поле (int) в таблице по которой осуществляется сортировка записей.Как сделать что бы скрип выбрал все от 1 по возрастанию, а потом уже нули?


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
caballero
Отправлено: 25 Января, 2014 - 01:47:15
Post Id


Активный участник


Покинул форум
Сообщений всего: 5998
Дата рег-ции: Сент. 2011  
Откуда: Харьков


Помог: 126 раз(а)




например два запроса через union


-----
Бесплатная система складского учета с открытым кодом https://zippy[dot]com[dot]ua/zstore
 
 Top
Мелкий Супермодератор
Отправлено: 25 Января, 2014 - 08:16:38
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)





По старому обыкновению, мог напутать ASC/DESC


-----
PostgreSQL DBA
 
 Top
jonston
Отправлено: 25 Января, 2014 - 18:21:07
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




Мелкий пишет:
По старому обыкновению, мог напутать ASC/DESC

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


помогло
CODE (SQL):
скопировать код в буфер обмена
  1. ORDER BY  int = 0, int ASC
.Объясните пожалуйста как компилятор обрабатывает сей запрос.А то что то не доходит.

(Отредактировано автором: 25 Января, 2014 - 18:35:08)



-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
green_man
Отправлено: 25 Января, 2014 - 18:34:32
Post Id


Новичок


Покинул форум
Сообщений всего: 55
Дата рег-ции: Июль 2012  


Помог: 6 раз(а)




Зачем именно такой порядок?
Неудобно цикл делать?Улыбка
 
 Top
jonston
Отправлено: 25 Января, 2014 - 18:47:20
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




green_man пишет:
Зачем именно такой порядок?
Неудобно цикл делать?Улыбка


Ну смотри если тебе интересно.Есть города и регионы (все в одной таблице.Знаю что не удобно но переделывать не вариант).У них есть поле порядок сортировки.Для удобства использования нужно выводить Республика Адыгея, Майкоп и так далее.То есть Регион и столица региона.Контентщик отсортировал все регионы и города в порядке возрастания по алфавиту.То есть Адыгея идет первой по алфавиту и потом должен идти региональный центр - Майкоп.Соответственно 1 и 2.И так далее.Но остались еще города у которых по умолчанию стоит ноль (не региональные центры но нужные крупные города).Если выводить все по порядку, то нулевые будут первыми.А в приоритете должны быть регионы и их столицы.Не знаю доходчиво ли описал, но как смог.


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
green_man
Отправлено: 25 Января, 2014 - 18:58:22
Post Id


Новичок


Покинул форум
Сообщений всего: 55
Дата рег-ции: Июль 2012  


Помог: 6 раз(а)




Первое что приходит на ум это конечно union, а так подумать надо.
 
 Top
jonston
Отправлено: 25 Января, 2014 - 20:06:51
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




green_man пишет:
Первое что приходит на ум это конечно union, а так подумать надо.
Решил уже.Мелкий подсказал почти правильный вариант.Только вмеcто > z я поставил =.


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
Мелкий Супермодератор
Отправлено: 25 Января, 2014 - 20:21:14
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




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


-----
PostgreSQL DBA
 
 Top
jonston
Отправлено: 25 Января, 2014 - 20:41:32
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




Мелкий пишет:
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 по возрастающей, а потом уже нули.Ведь по логике должные нули, а потом все по возрастающей?


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
Мелкий Супермодератор
Отправлено: 25 Января, 2014 - 20:43:34
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Ну я и говорю, постоянно путаю направления сортировок...


-----
PostgreSQL DBA
 
 Top
jonston
Отправлено: 25 Января, 2014 - 20:52:20
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




Мелкий пишет:
Ну я и говорю, постоянно путаю направления сортировок...

Не, не, не.Смотри.Первое интерпретатор понимает как отобрать все нулевые значения по возрастанию (то есть нули), а потом уже int asc (остальные от 1+...)


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
EuGen Администратор
Отправлено: 26 Января, 2014 - 11:17:51
Post Id


Профессионал


Покинул форум
Сообщений всего: 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)


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
jonston
Отправлено: 26 Января, 2014 - 14:52:57
Post Id



Посетитель


Покинул форум
Сообщений всего: 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 и потом сортирует уже в соответствии с ним.


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB