Новости Joomla

0 Пользователей и 1 Гость просматривают эту тему.
  • 1 Ответов
  • 1206 Просмотров
*

evsmusic

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Всем привет! Пишу модуль поиска для вирта, чтобы при вводе артикула, мне выводиля искомый товар в внизу у него появлялись товары, которые являются дочерними от искомого товара. С этим разобрался. Мозг вспух, и что-то так и не могу догнать, как теперь сформировать запрос, чтобы при поиске дочернего товара так же внизу появлялся список родительского товара.

Итак, подробнее: в базе в таблице #__vm_product есть колонка под названием `product_parent_id`, в ней умолчанием забивается айди родительского товара. Тоесть есть товары с айдихами: 10,11,12,13,14,15, 10 - родительский, и его айди пишется в `product_parent_id` у дочерних товаров. Тоесть, 11,12,13 и тд имеют `product_parent_id = 10`, соответственно 10 - не имеет parent_id, точнее он просто НУЛЬ .
тут все просто, чтобы получить детей родителя - 10, надо тупо сделать так -
Код
SELECT `product_sku` FROM `#__virtuemart_product` WHERE product_parent_id =" . $result->virtuemart_product_id
- в $result собственно выбирается искомая айдиха товара связанная с его артикулом.

Теперь вопрос - что надо сформировать чтобы у детей показать остальных детей данного родителя и самого родителя.
*

evsmusic

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
В общем кому интересно, решил временно текущую проблема следующим, далеко не самым красивым образом, но пока работает:

Код

<?php

$db =& JFactory::getDBO();
//выбираем id родительского товара
$qurery1 = "SELECT product_parent_id
 FROM #__virtuemart_products
WHERE product_parent_id != 0
  AND virtuemart_product_id =".$result->virtuemart_product_id ."";
 
$db->setQuery($qurery1);

$childs_ch = $db->loadResultArray();

$parent_id = $childs_ch[0];

//если айдишка родительского товара отстутствует, тоесть в запрос пришел сам родитель, то надо вывести всего лишь детей
if(is_null($parent_id)){
$query2 = "SELECT product_sku FROM #__virtuemart_products
WHERE product_parent_id = ".$result->virtuemart_product_id ."";
 
$db->setQuery($query2, 0, $limit);
$childs = $db->loadObjectList();

}else{

//в ином случае выводим все что имеем: все дочение товары относительно папы текущего товара, самого папу, и себя
$query2 = "SELECT product_sku,virtuemart_product_id FROM #__virtuemart_products
  WHERE product_parent_id = ".$result->virtuemart_product_id ."
OR product_parent_id = ".$parent_id."        
OR virtuemart_product_id = ".$parent_id."
 ";
 
$db->setQuery($query2, 0, $limit);
$childs = $db->loadObjectList();
}

echo '<p><div style="display: inline-block;margin-top: 12px;">Из этой же категории: ';
echo '<span>';

if($childs){
foreach($childs as $key => $row){
$childlink = "index.php?option=com_virtuemart&view=productdetails&virtuemart_product_id=" .$row->virtuemart_product_id ."";
$chlink = htmlspecialchars(stripslashes($childlink));

?><a href="<?=$childlink?>"><?=$row->product_sku?></a> || <?php
#if($result->text){echo $result->text;}
}
}else{
echo 'Нет совпадений</p>';
}
echo '</span>';
echo '</div>';

?>


Минусы этой конструкции -
1: Не выводится краткое описание родителя к детям;
2: По желанию можно убрать вывод самого себя в дочерних товарах.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Исправить подтягивание значений контактов клиента из базы SQL

Автор Nessy74

Ответов: 5
Просмотров: 869
Последний ответ 31.12.2015, 07:05:16
от Филипп Сорокин
Изменить запрос поиска mod_virtuemart_search

Автор Tokyo

Ответов: 1
Просмотров: 1181
Последний ответ 06.06.2013, 02:03:57
от fsv
Поиск по полям базы данных

Автор valensy

Ответов: 1
Просмотров: 1101
Последний ответ 08.09.2012, 21:39:45
от flyingspook
SQL запрос

Автор Infosakh

Ответов: 6
Просмотров: 1870
Последний ответ 29.05.2012, 21:06:09
от asimo
Отображение количества товаров в категориях. Требуется помощь по изменению не дефолтового модуля кат

Автор mmontana

Ответов: 0
Просмотров: 1104
Последний ответ 22.01.2010, 02:13:55
от mmontana