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

Форум MySQL

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

 

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

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

тема: Сложная сортировка
 
 автор: BAHO   (12.07.2005 в 12:35)   письмо автору
 
 

хы... вот теперь такая трабла...
можно ли сортировать данные, извлечённые из БД, с помощью order by так, чтобы сортировка проходила по другому полю из дрйгой таблицы ентой же БД.
Т.е. есть вот такая струтура в таблице g2_images
id id_cat id_subcat path
1 2 5 htruhrt1.jpg
2 2 4 htruhrt2.jpg
3 2 4 htruhrt3.jpg
4 2 3 htruhrt4.jpg
5 2 5 htruhrt5.jpg

и ещё одна таблица g2_subcategories
id id_cat name
3 2 Мото
4 2 Авто
5 2 Супер

так вот, мне надо сортировать данные в первой таблице по субкатегории, но при этом сортировка проходила по имени субкатегории из второй таблицы...

Раз mySQL является РЕЛЯЦИОННОЙ базой данных, то думаю, енто можно реализовать, но как... я пока не знаю

   
 
 автор: cheops   (12.07.2005 в 13:04)   письмо автору
 
   для: BAHO   (12.07.2005 в 12:35)
 

Хм... можно поступить примерно так
SELECT g2_images.id,
       g2_images.id_cat,
       g2_images.id_subcat
       g2_images.path
FROM g2_images, g2_subcategories
WHERE g2_subcategories.id = g2_images.id_subcat
GROUP BY g2_images.id
ORDER BY g2_subcategories.name

   
 
 автор: BAHO   (12.07.2005 в 20:09)   письмо автору
 
   для: cheops   (12.07.2005 в 13:04)
 

ага, возникает такой баг... а вот если поле id_subcat в таблице g2_images имеет значение 0, но при этом в таблице g2_subcategroies поля id со значением 0 нет и быть не может... как поступить? пробовал с помощью UNION... не получается, говорит что ORDER BY и UNION в данном случае несовместимы... :(

   
 
 автор: cheops   (12.07.2005 в 21:51)   письмо автору
 
   для: BAHO   (12.07.2005 в 20:09)
 

Здесь нужно левое объединение таблиц, как раз и созданное для таких случаев
SELECT g2_images.id, 
       g2_images.id_cat, 
       g2_images.id_subcat 
       g2_images.path 
FROM g2_images LEFT JOIN g2_subcategories 
WHERE g2_subcategories.id = g2_images.id_subcat 
GROUP BY g2_images.id 
ORDER BY g2_subcategories.name

   
 
 автор: BAHO   (13.07.2005 в 10:24)   письмо автору
 
   для: cheops   (12.07.2005 в 21:51)
 

теперь он говорит syntax error... ну запятую после g2_images.id_subcat я просёк, а ошибка такая:

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE g2_subcategories.id = g2_images.id_subcat
GROUP BY g2_im

   
 
 автор: cheops   (13.07.2005 в 11:46)   письмо автору
 
   для: BAHO   (13.07.2005 в 10:24)
 

-

   
 
 автор: cheops   (13.07.2005 в 11:47)   письмо автору
 
   для: BAHO   (13.07.2005 в 10:24)
 

А версия MySQL какая?

   
 
 автор: BAHO   (13.07.2005 в 16:16)   письмо автору
 
   для: cheops   (13.07.2005 в 11:47)
 

4.1.18 но енто только у меня... а есть в ентом разница с версией 3?

   
 
 автор: cheops   (13.07.2005 в 19:18)   письмо автору
 
   для: BAHO   (13.07.2005 в 16:16)
 

Ну разница между 4.1.18 и 4.23 не просто большая, а очень большая, а запрос не работает именно под 4.1.18 или только под более раннюю версию?

   
 
 автор: BAHO   (14.07.2005 в 13:45)   письмо автору
 
   для: cheops   (13.07.2005 в 19:18)
 

именно под 4.1.18... под другие тестил, но всё же желательно что нибудь универсальное! плиз! пАмАгИтЕ! у меня срывается дело!

   
 
 автор: cheops   (14.07.2005 в 19:43)   письмо автору
 
   для: BAHO   (14.07.2005 в 13:45)
 

А немогли бы вы выложить кусочек дампа каждой из таблицы, чтобы я на локальном сервере смог с запросом повозиться. И ещё какая минимальная версия сервера MySQL будет использоваться?

   
 
 автор: BAHO   (14.07.2005 в 23:01)   письмо автору
 
   для: cheops   (14.07.2005 в 19:43)
 

Вот в аттаче:

   
 
 автор: BAHO   (15.07.2005 в 17:59)   письмо автору
 
   для: BAHO   (14.07.2005 в 23:01)
 

АУ!

   
 
 автор: cheops   (15.07.2005 в 20:32)   письмо автору
 
   для: BAHO   (15.07.2005 в 17:59)
 

Попробуйте следующий запрос
SELECT g2_images.id, 
       g2_images.id_cat, 
       g2_images.id_subcat,
       g2_images.path 
FROM g2_images LEFT JOIN g2_subcategories 
ON g2_subcategories.id = g2_images.id_subcat 
GROUP BY g2_images.id 
ORDER BY g2_subcategories.name

   
 
 автор: BAHO   (16.07.2005 в 08:53)   письмо автору
 
   для: cheops   (15.07.2005 в 20:32)
 

хы хы... вот не поверите! работает! пасибо БОЛЬШОЕ!

   
Rambler's Top100
вверх

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