|
|
|
| Здравствуйте, уважаемые мега супер программисты!
Мне нужно с таблицы вытащить все записи, при чём порядочнные по ID, но те записи у которых в колонке `MyColumn` значение равно 1 должны быть даже не смотря на то что они не подходят под условие сортировки, быть в самом начале. | |
|
|
|
|
|
|
|
для: 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
|
| |
|
|
|
|
|
|
|
для: Valick
(03.10.2012 в 22:30)
| | А поменьше запросов? =)
SELECT * FROM `tab_name` ORDER BY if(myColumn=1,0,1),id
|
P.S. Долго думал какие записи считать порядочными, а какие непорядочными =)))) | |
|
|
|
|
|
|
|
для: Sfinks
(03.10.2012 в 22:50)
| | оппачки, не пхал ни разу условие в сортировку, надо взять на заметку, спасибо. | |
|
|
|
|
|
|
|
для: 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
| , особенно если нам результат работы подзапроса не нужен. | |
|
|
|
|
|
|
|
для: Valick
(03.10.2012 в 23:36)
| | А еще прикольнее первый запрос будет выглядеть с неявным приведением типов:
SELECT * FROM `tab_name` ORDER BY NOT myColumn=1, id
| =)))) | |
|
|
|