OpenCart 🇺🇦

Схема

public mixed getProduct ( int $product_id )

Аргументы

Аргумент Возможный тип Описание
$product_id int

Описание

Если продукт найден, вернет массив, иначе булевый false. При успешной выборке ассоциативный массив будет содержать следующие поля:
Ключ Тип Описание Пример значения
product_id int ID продукта 5
name string Название продукта IPhone 5S
description string Описание продукта iPhone 5 — смартфон корпорации Apple, представляет шестое поколение iPhone и является преемником iPhone 4S. Изначально работал на операционной системе iOS 6, которая официально стала доступна 19 сентября 2012 года[8][9], затем получил обновление до iOS 7. Далее получил обновление до iOS 8. Его преемниками стали iPhone 5S и 5C.
meta_description string Описание для мета-тега description ...
meta_keywords string Ключевые слова для мета-тега keywords телефон, купить, apple, iphone
tag string телефон, iphone
model string Модель продукта iphone5c3354m
sku int SKU-номер ...
upc, ean, jan, isbn, mpn
location string ... ...
quantity int Количество товара на складе (единиц) 5
stock_status string Текстовое название статуса товара на складе
image string Основная картинка продукта data/products/11313.jpg
manufacturer_id int ID производителя 124
manufacturer string Название производителя Apple
price float Цена товара с учетом дисконта 244.42
special float Цена товара с учетом скидки 124.55
reward ... ... ...
points int ... 12
tax_class_id int ID класса налога 9
date_available string Дата, с которой продукт доступен для продажи 2014-01-01
weight float Вес 12.444
weight_class_id int ... 1
length float Глубина 4.42
width float Длинна 15.4
height float Высота 1.2
length_class_id int ... 1
subtract int Количество единиц товара, отнимаемых при добавлении в корзину 1 (почти всегда 1)
rating int Средний рейтинг товара (по оценкам пользователей) 3
reviews int Количество отзывов 0
minimum int Минимальное количество товаров к заказу 1
sort_order int Порядок сортировки в таблице 1
status int Статус продукта 1 Так как в условии WHERE есть строка status=1, то здесь значение всегда 1
date_added string Дата добавления продукта 2011-03-29 14:42:07
date_modified string Дата последнего редактирования продукта 2011-03-29 14:42:07
viewed int Количество просмотров продукта 10

Пример использования:

// вызов из контроллера catalog/controller/product/product.php
$this->load->model('catalog/product');
$product_info = $this->model_catalog_product->getProduct($product_id);

Исходный код

if ($this->customer->isLogged()) {
	$customer_group_id = $this->customer->getCustomerGroupId();
} else {
	$customer_group_id = $this->config->get('config_customer_group_id');
}	

$query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$customer_group_id . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$customer_group_id . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special, (SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND customer_group_id = '" . (int)$customer_group_id . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'");

if ($query->num_rows) {
	return array(
		'product_id'       => $query->row['product_id'],
		'name'             => $query->row['name'],
		'description'      => $query->row['description'],
		'meta_description' => $query->row['meta_description'],
		'meta_keyword'     => $query->row['meta_keyword'],
		'tag'              => $query->row['tag'],
		'model'            => $query->row['model'],
		'sku'              => $query->row['sku'],
		'upc'              => $query->row['upc'],
		'ean'              => $query->row['ean'],
		'jan'              => $query->row['jan'],
		'isbn'             => $query->row['isbn'],
		'mpn'              => $query->row['mpn'],
		'location'         => $query->row['location'],
		'quantity'         => $query->row['quantity'],
		'stock_status'     => $query->row['stock_status'],
		'image'            => $query->row['image'],
		'manufacturer_id'  => $query->row['manufacturer_id'],
		'manufacturer'     => $query->row['manufacturer'],
		'price'            => ($query->row['discount'] ? $query->row['discount'] : $query->row['price']),
		'special'          => $query->row['special'],
		'reward'           => $query->row['reward'],
		'points'           => $query->row['points'],
		'tax_class_id'     => $query->row['tax_class_id'],
		'date_available'   => $query->row['date_available'],
		'weight'           => $query->row['weight'],
		'weight_class_id'  => $query->row['weight_class_id'],
		'length'           => $query->row['length'],
		'width'            => $query->row['width'],
		'height'           => $query->row['height'],
		'length_class_id'  => $query->row['length_class_id'],
		'subtract'         => $query->row['subtract'],
		'rating'           => round($query->row['rating']),
		'reviews'          => $query->row['reviews'] ? $query->row['reviews'] : 0,
		'minimum'          => $query->row['minimum'],
		'sort_order'       => $query->row['sort_order'],
		'status'           => $query->row['status'],
		'date_added'       => $query->row['date_added'],
		'date_modified'    => $query->row['date_modified'],
		'viewed'           => $query->row['viewed']
	);
} else {
	return false;
}