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

Форум MySQL

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

 

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

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

тема: Cортировка таблицы по трем полям
 
 автор: vilk   (27.03.2011 в 15:40)   письмо автору
 
 

Есть поле1, поле2, и поле3. В первую очередь нужно сортировать по полю1(то есть чтобы в нем было значение больше нуля). Затем сортировка должна идти по полю3 со значением - yes и с условием, что в поле2 стоит единичка. И после этого всего должны выбираться записи в которых поле1 имеет значение меньше одного.

Каким образом можно сделать сортировку с такими критериями по этим трем полям?

Очень жду помощи и заранее большое спасибо!

  Ответить  
 
 автор: psychomc   (27.03.2011 в 15:50)   письмо автору
 
   для: vilk   (27.03.2011 в 15:40)
 

судя по всему сортировка будет только по "поле1" и запрос будет выглядеть как-то так (если я правильно понял задачу)

SELECT * FROM tablename
WHERE поле3='yes' AND поле2=1
ORDER BY поле1 DESC

  Ответить  
 
 автор: vilk   (27.03.2011 в 16:24)   письмо автору
 
   для: psychomc   (27.03.2011 в 15:50)
 

Спасибо за ответ но дело в том, что должны выводится все записи не зависимо от того, что в поле3 и в поле2. Просто в сортировке должно учитываться то, что в первую очередь выбираются записи где поле1 больше нуля, потом сразу в этом же запросе выбираются поля в которых поле3='yes' AND поле2=1 и затем в этом же запросе выбираются записи в которых поле1 меньше одного не зависимо от того, что в поле2 и поле3 .

То есть то, что я описал, это этапы сортировки должны быть такими, но запрос один который выбирает все данные.

  Ответить  
 
 автор: cheops   (27.03.2011 в 16:52)   письмо автору
 
   для: vilk   (27.03.2011 в 16:24)
 

Тогда можно поступить следующим образом
SELECT * FROM tbl
ORDER BY поле1, IF(поле3='yes' AND поле2=1, 0, 1)

  Ответить  
 
 автор: vilk   (27.03.2011 в 17:32)   письмо автору
 
   для: cheops   (27.03.2011 в 16:52)
 

Отлично. Большое спасибо!

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

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