SQL запросы / SQL запросы для товаров

Заметка создана: 13 января 2035 г.
НАЗНАЧАЕМ ВАЛЮТУ ВСЕМ ТОВАРАМ
UPDATE `polyankake_hs`.`shop_items` SET `shop_currency_id` = '1' WHERE `shop_id` = 123; // вместо 123 указать ID магазина
Меняем тип товара (делимый - 2, электронный - 1, обычный - 0)
UPDATE `shop_items` SET `type` = '2'
Удалить товары
// Удаляем товары, которых нет на всех складах
UPDATE `shop_items` SET `deleted` = (
SELECT IF(SUM(`shop_warehouse_items`.`count`) = 0, 0, 0)
FROM `shop_warehouse_items` WHERE `shop_warehouse_items`.`shop_item_id` = `shop_items`.`id`
)
WHERE `shop_items`.`shop_id` = 1;  // номер магазина заменить

// Удаляем все товары из указанного магазина
UPDATE `shop_items` SET `deleted` = 1 WHERE `shop_id` = 123 // вместо 123 указать ID магазина

// Удаляем товары у которых отключена активность
UPDATE `shop_items` SET `deleted` = 1 WHERE `shop_items`.`active` = 0

UPDATE `shop_items` SET `deleted` = 1 WHERE `deleted` = 1

// Удаляем товары у которых отключена индексация
UPDATE `shop_items` SET `deleted` = 1 WHERE `shop_items`.`indexing` = 0
Убрать все сопутствующие для всех товаров
TRUNCATE TABLE `shop_item_associated`;
Установить всем товарам на складе 55 остаток в единицу
UPDATE `shop_warehouse_items` SET `count` = 1 WHERE `shop_warehouse_id` = 55;
Назначаем всем товарам количество на основном складе
UPDATE `shop_warehouse_items` SET `count` = '100'
Назначаем количество только товарам с количеством = 0
UPDATE `shop_warehouse_items` SET `count` = '999' WHERE `count` = 0;
Установить "индексировать" товарам с наличием на складе и не индексировать с нулевым остатком
UPDATE `shop_items` SET `shop_items`.`indexing` = (

SELECT IF(SUM(`shop_warehouse_items`.`count`) > 0, 1, 0)

FROM `shop_warehouse_items` WHERE `shop_warehouse_items`.`shop_item_id` = `shop_items`.`id`

)
WHERE `shop_items`.`shop_id` = 123; // вместо 123 указать ID магазина

UPDATE `shop_items` SET `shop_items`.`indexing` = 0 WHERE `shop_items`.`active` = 0

Удалить артикул у всех товаров с Артикулом

UPDATE `shop_items` SET `marking` = '' WHERE `marking` != '' AND `shop_id` = 123; // вместо 123 указать ID магазина

Добавить к названию товара какое-то слово (символ) в определённой группе

update shop_items set name = concat('Пицца ', name) where shop_group_id = 746

Добавить к названию товара какое-то слово (символ) в нескольких группах

update shop_items set name = concat('Пицца ', name) where shop_group_id IN (746, 747, 748)

Добавить к названию товара артикул в определённых группах

update shop_items set name = concat(name, ' ', marking) where shop_group_id IN (746, 747, 748)

Удалить определённый символ из названия товара

UPDATE `shop_items` SET name = REPLACE(`name`,'*','х' ) // заменяем "*" на "х"

Отключить активность всем Купонам

UPDATE `shop_purchase_discount_coupons` SET `active` = 0

Удаление значений несуществующих товаров

DELETE `property_value_strings`
FROM `property_value_strings`
LEFT JOIN `shop_items` ON `property_value_strings`.`entity_id` = `shop_items`.`id`
WHERE `shop_items`.`id` IS NULL

DELETE `shop_warehouse_items`
FROM `shop_warehouse_items`
LEFT JOIN `shop_items` ON `shop_warehouse_items`.`shop_item_id` = `shop_items`.`id` 
WHERE `shop_items`.`id` IS NULL

SELECT `shop_item_prices`.`id`, `shop_items`.`id`
FROM `shop_item_prices`
LEFT JOIN `shop_items` ON `shop_item_prices`.`shop_item_id` = `shop_items`.`id`
WHERE `shop_items`.`id` IS NULL

Выбор товаров из группы и подгруппы

SELECT `shop_items`.* 
FROM `shop_items`
JOIN `shop_groups` ON `shop_groups``.id` = `shop_items`.`shop_group_id`
	AND (`shop_groups`.`parent_id` IN (1,2) OR `shop_groups`.`id` IN (1,2))
WHERE `shop_items`.`shortcut_id` = 0 AND `shop_items`.`modification_id` = 0

Поиск дублей в MySQL

SELECT COUNT(`path`) AS `count`, `id`, `shop_group_id`, `shop_producer_id`, `name`, `active`, `path`, `deleted` FROM `shop_items` WHERE `shop_id` = 1 AND `modification_id` = 0 AND `shortcut_id` = 0 GROUP BY `path` HAVING COUNT(`path`) > 1

Установить значение "1 " для свойства с ID 555

UPDATE `property_value_ints` SET value = 1 WHERE `property_id` = 555

Удалить SEO заголовки title, description, keywords у товаров определенной группы

UPDATE `shop_items` SET `seo_title` = '', `seo_description` = '',`seo_keywords`  = '' WHERE `shop_group_id` = 123

Удаление значений свойств у товаров

Удалить все свойства тип "Строка" с ID = 999 у всех товаров

DELETE FROM property_value_strings WHERE property_id = 999;

Удалить все свойства тип "Строчка" с ID = 998 и ID = 999 у всех товаров

DELETE FROM property_value_strings WHERE property_id IN (998,999)

Если удалили большое количество свойств (большое количество — это несколько сотен), то оптимизируем таблицу, при удалении пары десятков не имеет смысла.

OPTIMIZE TABLE property_value_strings;

Какие типы свойств к какой таблице относятся:

property_value_datetimes - "Дата [type=8]", "Дата-время [type=9]"
property_value_files - "Файл [type=2]"
property_value_floats - "Число с плавающей запятой [type=11]"
property_value_ints - "Список[type=3]", "Информационная система [type=5]", "Флажок [type=7]", "Интернет-магазин [type=12]"
property_value_strings - "Строка [type=1]", "Скрытое поле [type=10]"
property_value_texts - "Большое текстовое поле [type=4]", "Визуальный редактор [type=6]"


ДОСКА ОБЪЯВЛЕНИЙ

Обнуляем дату окончания показа объявлений

UPDATE `shop_items` SET `end_datetime` = '0000-00-00 00:00:00' WHERE `shop_id` = 123; // вместо 123 указать ID магазина