Jump to content
kikaridza123

Как удалить товары с пустым описанием?

Recommended Posts

Подскажите пожалуйста как удалить товары из БД все товары у которых пустое описание?
Помогите написать правильный запрос в базу.
Если такое возможно.

Share this post


Link to post
Share on other sites

А что не получается, или написать за вас нужно?

Share this post


Link to post
Share on other sites
59 минут назад, kikaridza123 сказал:

Подскажите пожалуйста как удалить товары из БД все товары у которых пустое описание?
Помогите написать правильный запрос в базу.
Если такое возможно.

 

лучше их собрать и удалить через deleteProduct чтобы все таблицы почистить

  • +1 1

Share this post


Link to post
Share on other sites

Сколько языков в магазине?

Share this post


Link to post
Share on other sites

Но товары с <p></p> - по идее тоже пустые

И как выше было сказано, про языки
И ка выше было сказано - одним запросом не обойтись

Share this post


Link to post
Share on other sites

Одним не обойтись, а двумя можно всё грохнуть )

Это для одного языка

Если языков больше - надо запрос подшаманить

Если описания с пустыми HTML тегами тоже считать пустыми, можно вместо t0.description = '' отбирать по длине описания CHAR_LENGTH(t0.description) < 20

DELETE `t01`,`t02`,`t03`,`t04`,`t05`,`t06`,`t07`,`t08`,`t09`,`t10`,`t11`,`t12`,`t13`,`t14`,`t15`,`t16`,`t17`,`t18`,`t19`
FROM `oc_product_description`		AS `t0`
LEFT JOIN `oc_product`			AS `t01` ON(`t0`.`product_id` = `t01`.`product_id`) 
LEFT JOIN `oc_product_attribute`	AS `t02` ON(`t0`.`product_id` = `t02`.`product_id`)
LEFT JOIN `oc_product_discount`		AS `t03` ON(`t0`.`product_id` = `t03`.`product_id`)
LEFT JOIN `oc_product_filter`		AS `t04` ON(`t0`.`product_id` = `t04`.`product_id`)
LEFT JOIN `oc_product_image`		AS `t05` ON(`t0`.`product_id` = `t05`.`product_id`)
LEFT JOIN `oc_product_option`		AS `t06` ON(`t0`.`product_id` = `t06`.`product_id`)
LEFT JOIN `oc_product_option_value`	AS `t07` ON(`t0`.`product_id` = `t07`.`product_id`)
LEFT JOIN `oc_product_recurring`	AS `t08` ON(`t0`.`product_id` = `t08`.`product_id`)
LEFT JOIN `oc_product_related`		AS `t09` ON(`t0`.`product_id` = `t09`.`product_id`)
LEFT JOIN `oc_product_related`		AS `t10` ON(`t0`.`product_id` = `t10`.`related_id`)
LEFT JOIN `oc_product_reward`		AS `t11` ON(`t0`.`product_id` = `t11`.`product_id`)
LEFT JOIN `oc_product_special`		AS `t12` ON(`t0`.`product_id` = `t12`.`product_id`)
LEFT JOIN `oc_product_to_category`	AS `t13` ON(`t0`.`product_id` = `t13`.`product_id`)
LEFT JOIN `oc_product_to_download`	AS `t14` ON(`t0`.`product_id` = `t14`.`product_id`)
LEFT JOIN `oc_product_to_layout`	AS `t15` ON(`t0`.`product_id` = `t15`.`product_id`)
LEFT JOIN `oc_product_to_store`		AS `t16` ON(`t0`.`product_id` = `t16`.`product_id`)
LEFT JOIN `oc_review`			AS `t17` ON(`t0`.`product_id` = `t17`.`product_id`)
LEFT JOIN `oc_coupon_product`		AS `t18` ON(`t0`.`product_id` = `t18`.`product_id`)
LEFT JOIN `oc_url_alias`		AS `t19` ON(CONCAT('product_id=',`t0`.`product_id`) = `t19`.`query`)
WHERE `t0`.`description = '';

DELETE `pd` 
FROM `oc_product_description` AS `pd`
LEFT JOIN `oc_product` AS `p` ON(`pd`.`product_id` = `p`.`product_id`)
WHERE `p`.`product_id` IS NULL;

 

  • +1 1

Share this post


Link to post
Share on other sites

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

Share this post


Link to post
Share on other sites
21 час назад, kikaridza123 сказал:

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

руками постранично или скопом?

вопрос смежный - как удалить все товары разом? задублировалось очень много, не хочу разбирать овер 20к товаров...

Share this post


Link to post
Share on other sites
В 04.10.2019 в 20:34, Yesvik сказал:

Одним не обойтись, а двумя можно всё грохнуть )

Это для одного языка

Если языков больше - надо запрос подшаманить

Если описания с пустыми HTML тегами тоже считать пустыми, можно вместо t0.description = '' отбирать по длине описания CHAR_LENGTH(t0.description) < 20


DELETE `t01`,`t02`,`t03`,`t04`,`t05`,`t06`,`t07`,`t08`,`t09`,`t10`,`t11`,`t12`,`t13`,`t14`,`t15`,`t16`,`t17`,`t18`,`t19`
FROM `oc_product_description`		AS `t0`
LEFT JOIN `oc_product`			AS `t01` ON(`t0`.`product_id` = `t01`.`product_id`) 
LEFT JOIN `oc_product_attribute`	AS `t02` ON(`t0`.`product_id` = `t02`.`product_id`)
LEFT JOIN `oc_product_discount`		AS `t03` ON(`t0`.`product_id` = `t03`.`product_id`)
LEFT JOIN `oc_product_filter`		AS `t04` ON(`t0`.`product_id` = `t04`.`product_id`)
LEFT JOIN `oc_product_image`		AS `t05` ON(`t0`.`product_id` = `t05`.`product_id`)
LEFT JOIN `oc_product_option`		AS `t06` ON(`t0`.`product_id` = `t06`.`product_id`)
LEFT JOIN `oc_product_option_value`	AS `t07` ON(`t0`.`product_id` = `t07`.`product_id`)
LEFT JOIN `oc_product_recurring`	AS `t08` ON(`t0`.`product_id` = `t08`.`product_id`)
LEFT JOIN `oc_product_related`		AS `t09` ON(`t0`.`product_id` = `t09`.`product_id`)
LEFT JOIN `oc_product_related`		AS `t10` ON(`t0`.`product_id` = `t10`.`related_id`)
LEFT JOIN `oc_product_reward`		AS `t11` ON(`t0`.`product_id` = `t11`.`product_id`)
LEFT JOIN `oc_product_special`		AS `t12` ON(`t0`.`product_id` = `t12`.`product_id`)
LEFT JOIN `oc_product_to_category`	AS `t13` ON(`t0`.`product_id` = `t13`.`product_id`)
LEFT JOIN `oc_product_to_download`	AS `t14` ON(`t0`.`product_id` = `t14`.`product_id`)
LEFT JOIN `oc_product_to_layout`	AS `t15` ON(`t0`.`product_id` = `t15`.`product_id`)
LEFT JOIN `oc_product_to_store`		AS `t16` ON(`t0`.`product_id` = `t16`.`product_id`)
LEFT JOIN `oc_review`			AS `t17` ON(`t0`.`product_id` = `t17`.`product_id`)
LEFT JOIN `oc_coupon_product`		AS `t18` ON(`t0`.`product_id` = `t18`.`product_id`)
LEFT JOIN `oc_url_alias`		AS `t19` ON(CONCAT('product_id=',`t0`.`product_id`) = `t19`.`query`)
-- WHERE `t0`.`description = '';

DELETE `pd` 
FROM `oc_product_description` AS `pd`
LEFT JOIN `oc_product` AS `p` ON(`pd`.`product_id` = `p`.`product_id`)
-- WHERE `p`.`product_id` IS NULL;

 

я так понимаю это все отношения в которых хранится инфа по товарам?

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

Share this post


Link to post
Share on other sites

Это все таблицы которые зачищаются при удалении товаров через админку. При этом могут остаться упоминания о товарах в таблицах oc_cart, oc_order_product, oc_customer_wishlist, oc_return

Всё зависит от того с какой целью делается зачистка...

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
You are posting as a guest. If you have an account, please sign in.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Recently Browsing   0 members

    No registered users viewing this page.

×

Important Information

On our site, cookies are used and personal data is processed to improve the user interface. To find out what and what personal data we are processing, please go to the link. If you click "I agree," it means that you understand and accept all the conditions specified in this Privacy Notice.