Перейти к содержанию
cherkas

запрос в БД к атрибутам

Рекомендуемые сообщения

Здравствуйте, в catalog/model/catalog/product.php есть код:

public function getProductAttributes($product_id) {
		$product_attribute_group_data = array();
		
		$product_attribute_group_query = $this->db->query("SELECT ag.attribute_group_id, agd.name FROM " . DB_PREFIX . "product_attribute pa LEFT JOIN " . DB_PREFIX . "attribute a ON (pa.attribute_id = a.attribute_id) LEFT JOIN " . DB_PREFIX . "attribute_group ag ON (a.attribute_group_id = ag.attribute_group_id) LEFT JOIN " . DB_PREFIX . "attribute_group_description agd ON (ag.attribute_group_id = agd.attribute_group_id) WHERE pa.product_id = '" . (int)$product_id . "' AND agd.language_id = '" . (int)$this->config->get('config_language_id') . "' GROUP BY ag.attribute_group_id ORDER BY ag.sort_order, agd.name");
		
		foreach ($product_attribute_group_query->rows as $product_attribute_group) {
			$product_attribute_data = array();
			
			$product_attribute_query = $this->db->query("SELECT a.attribute_id, ad.name, pa.text FROM " . DB_PREFIX . "product_attribute pa LEFT JOIN " . DB_PREFIX . "attribute a ON (pa.attribute_id = a.attribute_id) LEFT JOIN " . DB_PREFIX . "attribute_description ad ON (a.attribute_id = ad.attribute_id) WHERE pa.product_id = '" . (int)$product_id . "' AND a.attribute_group_id = '" . (int)$product_attribute_group['attribute_group_id'] . "' AND ad.language_id = '" . (int)$this->config->get('config_language_id') . "' AND pa.language_id = '" . (int)$this->config->get('config_language_id') . "' ORDER BY a.sort_order, ad.name");
			
			foreach ($product_attribute_query->rows as $product_attribute) {
				$product_attribute_data[] = array(
					'attribute_id' => $product_attribute['attribute_id'],
					'name'         => $product_attribute['name'],
					
					'text'         => $product_attribute['text']		 	
				);
			}
			    $product_attribute_group_data[] = array(
				'attribute_group_id' => $product_attribute_group['attribute_group_id'],
				'name'               => $product_attribute_group['name'],
				'attribute'          => $product_attribute_data
			);			
		}

 

я в БД в таблице  attribute_description добавил поле pop_description, оно должно будет выводиться в таблице атрибутов (в карточке товара) вместе с name из этой же таблицы.

 

Подскажите, как правильно добавить запрос и получить переменную?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

...

$product_attribute_query = $this->db->query("SELECT a.attribute_id, ad.name, ad.pop_descriptionpa.text FROM " . DB_PREFIX . "product_attribute pa LEFT JOIN " . DB_PREFIX . "attribute a ON (pa.attribute_id = a.attribute_id) LEFT JOIN " . DB_PREFIX . "attribute_description ad ON (a.attribute_id = ad.attribute_id) WHERE pa.product_id = '" . (int)$product_id . "' AND a.attribute_group_id = '" . (int)$product_attribute_group['attribute_group_id'] . "' AND ad.language_id = '" . (int)$this->config->get('config_language_id') . "' AND pa.language_id = '" . (int)$this->config->get('config_language_id') . "' ORDER BY a.sort_order, ad.name");

            
            
foreach ($product_attribute_query->rows as $product_attribute) {
                $product_attribute_data[] = array(
                    'attribute_id' => $product_attribute['attribute_id'],
                    'name' => $product_attribute['name'],
                    'pop_description' = > $product_attribute['pop_description'],
                    
'text' => $product_attribute['text']             
                
);
            }

...

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

ругается на   'pop_description' = > $product_attribute['pop_description'], и страница не грузится. Только ошибка высвечивается.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Кто нибудь еще может подсказать?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

ругается на   'pop_description' = > $product_attribute['pop_description'], и страница не грузится. Только ошибка высвечивается.

 

Как ругается?Так  !@#$%^ или так ^%$#@!

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

вверху страницы пишет ошибка номер строки ... в этой строке pop_description' = > $product_attribute['pop_description']. всё.  Сейчас опять внесу изменения и скину скриншот

 

 

Похоже разобрался

 

= > - между значками стоит пробел. Когда исправил ошибка ушла.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

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

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.