Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Сортировка по условию
 
 автор: p.pavluxa   (03.10.2012 в 20:21)   письмо автору
 
 

Здравствуйте, уважаемые мега супер программисты!

Мне нужно с таблицы вытащить все записи, при чём порядочнные по ID, но те записи у которых в колонке `MyColumn` значение равно 1 должны быть даже не смотря на то что они не подходят под условие сортировки, быть в самом начале.

  Ответить  
 
 автор: Valick   (03.10.2012 в 22:30)   письмо автору
 
   для: p.pavluxa   (03.10.2012 в 20:21)
 

SELECT * FROM `tab_name` WHERE MyColumn=1 ORDER BY id
UNION
SELECT * FROM `tab_name` WHERE MyColumn<>1 ORDER BY id

  Ответить  
 
 автор: Sfinks   (03.10.2012 в 22:50)   письмо автору
 
   для: Valick   (03.10.2012 в 22:30)
 

А поменьше запросов? =)
SELECT * FROM `tab_name` ORDER BY if(myColumn=1,0,1),id


P.S. Долго думал какие записи считать порядочными, а какие непорядочными =))))

  Ответить  
 
 автор: Valick   (03.10.2012 в 23:36)   письмо автору
 
   для: Sfinks   (03.10.2012 в 22:50)
 

оппачки, не пхал ни разу условие в сортировку, надо взять на заметку, спасибо.

  Ответить  
 
 автор: Sfinks   (04.10.2012 в 00:57)   письмо автору
 
   для: Valick   (03.10.2012 в 23:36)
 

В общем-то все что угодно можно запхнуть.
Я не проверял, но думаю, что и подзапрос можно.
Ведь можно же написать, например:
SELECT id
     , name
     , ( SELECT category FROM tbl2 WHERE id=t.id )
FROM tbl1 t
ORDER BY 3,1

Тогда почему не написать сразу
SELECT id
     , name
FROM tbl1 t
ORDER BY ( SELECT category FROM tbl2 WHERE id=t.id ),1
, особенно если нам результат работы подзапроса не нужен.

  Ответить  
 
 автор: Sfinks   (04.10.2012 в 01:53)   письмо автору
 
   для: Valick   (03.10.2012 в 23:36)
 

А еще прикольнее первый запрос будет выглядеть с неявным приведением типов:
SELECT * FROM `tab_name` ORDER BY NOT myColumn=1, id
=))))

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования