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

Форум MySQL

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

 

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

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: Помогите составить запрос

Сообщения:  [1-10]   [11-14] 

 
 автор: Trianon   (10.02.2010 в 21:58)   письмо автору
 
   для: Betty   (10.02.2010 в 19:55)
 

Так спрашивайте, какие именно конструкции неясны :)

  Ответить  
 
 автор: Betty   (10.02.2010 в 19:55)   письмо автору
 
   для: Trianon   (10.02.2010 в 10:22)
 

Еще раз с удовольствием благодарю!
Все работает. Единственно, что изменила LEFT JOIN на INNER JOIN, чтобы из "основной" таблицы выбирались ТОЛЬКО записи, для которых существуют нужный meta_key в таблице wp_postmeta.
Но, честно говоря, не все понимаю в вашем коде, буду искать, читать и разбираться... :)

  Ответить  
 
 автор: Trianon   (10.02.2010 в 10:22)   письмо автору
 
   для: Betty   (10.02.2010 в 10:03)
 

Учитесь мыслить конструкциями JOIN...ON
На самом деле это очень просто, если разок попробовать.

  Ответить  
 
 автор: Betty   (10.02.2010 в 10:03)   письмо автору
 
   для: Trianon   (09.02.2010 в 20:42)
 

Огромное спасибо!
"На глаз" не могу осилить... :) Разберусь - отпишусь о результате .

  Ответить  
 
 автор: Trianon   (09.02.2010 в 20:42)   письмо автору
 
   для: Betty   (09.02.2010 в 19:44)
 

>Требуется выбрать из таблицы значения 'post_id' для которых вернО СОЧЕТАНИЕ всех, введенных в поисковую форму данных.


Из таблицы выбираются строки, а не значения.
Фактически Вам, очевидно, нужно отобрать сущности , указуемые ключом post_id?
Это строки другой таблицы, если я правильно понимаю
SELECT p.* 
  FROM posts p
    LEFT JOIN wp_post_meta mo ON p.id = mo.post_id AND mo.meta_key = 'dog_otez'
    LEFT JOIN wp_post_meta mm ON p.id = mm.post_id AND mm.meta_key = 'dog_mama'
    LEFT JOIN wp_post_meta mz ON p.id = mz.post_id AND mz.meta_key = 'dog_zavodchik'
  WHERE
        COALESCE(mo.meta_value, '') LIKE '%$otez%'
    AND COALESCE(mm.meta_value, '') LIKE '%$mama%'
    AND COALESCE(mz.meta_value, '') LIKE '%$zavodchik%'


Понятно , что потребуется полное сканирование таблиц.

  Ответить  
 
 автор: Betty   (09.02.2010 в 19:49)   письмо автору
 
   для: Valick   (09.02.2010 в 14:10)
 

dog_zavodchik это тот, кто занимается разведением собак :)

Да, я тоже все больше склоняюсь к трем запросам... но, "надежда умирает последней..."

  Ответить  
 
 автор: Betty   (09.02.2010 в 19:46)   письмо автору
 
   для: Trianon   (09.02.2010 в 15:54)
 

дубль-пост...

  Ответить  
 
 автор: Betty   (09.02.2010 в 19:44)   письмо автору
 
   для: Trianon   (09.02.2010 в 15:54)
 

Я совсем запуталась... Видимо, все-таки не могу понятно объяснить задачу. Сейчас попытаюсь еще раз, "по простому" :).
Каталог собак. У каждой собаки своя учетная карточка. Основные данные хранятся в ДРУГОЙ таблице. Дополнительные данные находятся в вышеприведенной таблице. В столбце 'post_id' как раз и содержится ID основной записи (повторюсь, из другой таблицы).

Задача: организовать поиск. У формы поиска три текстовых поля:
Владелец собаки ( 'dog_vladelez'),
Отец собаки ('dog_papa'),
Мать собаки ('dog_mama')

Поля формы могут быть пустыми (т.е. ищется любое значение) или содержать какое-то слово (слог, букву и т.п.).

Требуется выбрать из таблицы значения 'post_id' для которых вернО СОЧЕТАНИЕ всех, введенных в поисковую форму данных.

Соответственно, дорогой Trianon, запрос из предыдущего поста не подходит, т.к. у wp_postmeta.meta_value могут быть три РАЗНЫХ значения...

  Ответить  
 
 автор: Trianon   (09.02.2010 в 15:54)   письмо автору
 
   для: Betty   (08.02.2010 в 15:00)
 

Я никого не бросаю, что Вы в самом деле.:)
Просто запарка небольшая на работе.

WHERE 
  wp_postmeta.meta_value LIKE '%somewhere%'
    AND wp_postmeta.meta_key IN ('dog_vladelez', 'dog_mama', 'dog_papa')


GROUP BY и вправду без понимания применять не стоит.

  Ответить  
 
 автор: Valick   (09.02.2010 в 14:10)   письмо автору
 
   для: Betty   (08.02.2010 в 15:00)
 

Зачем у вас GROUP BY в исходной задаче? может всетаки ORDER BY
И у Вас не совсем правильная логика, если бы искомые величины содержались в отдельных столбцах, то AND Вам помог бы (пример: wp_postmeta.meta_key = 'dog_mama' AND wp_postmeta.meta_value LIKE '%еще_что-то%'), у Вас же все в одном столбце.
Скрее всего Вам нужно три отдельных запроса, вот только до сих пор не понятно какую задачу Вы поставили перед собой.
___
кстати dog_zavodchik - это кто? О_о

  Ответить  

Сообщения:  [1-10]   [11-14] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

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