Jump to content
aseven

Запросы перегружают лимиты БД

Recommended Posts

Добрый день!

 

Хостинг Jino, регулярно сайт вылетает в блокировку базы данных из-за перегрузки вебсервера.

Remark: Да, купили KVM VDS готовим его для переноса, но это не получается сделать быстро.

 

Техподдержка пишет что проблема в этих запросах:

SELECT * FROM oc_product p LEFT JOIN oc_product_description pd ON (p.product_id = pd.product_id) WHERE pd.language_id = '1' GROUP BY p.product_id ORDER BY pd.name ASC;

SELECT p.product_id, p.quantity>0 as instock, (SELECT AVG(rating) AS total FROM oc_review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT price FROM oc_product_discount pd2 WHERE pd2.product_id = p.prod

 

Есть ли возможность как-то оптимизировать БД? Хотя бы как временное решение, что бы неделю прожить...

Может индексы создать какие-то?

Share this post


Link to post
Share on other sites

второй запрос недописали, первый запрос странный и что вы собственно хотите? врядли вам и VDS поможет

Share this post


Link to post
Share on other sites

Бегите от jino, чем быстрее тем лучше. Хостинг который ограничивает размер бд, количество запросов к бд, причем очень даже жестко, это не хостинг. 

Перенос на vds занимает несколько часов, еще 1-2 часа займет его настройка и оптимизация. Если нужна помощь с переносом и настройкой - обращайтесь. 

Share this post


Link to post
Share on other sites

в первом запросе GROUP BY p.product_id явно лишнее

Share this post


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

Добрый день!

 

Хостинг Jino, регулярно сайт вылетает в блокировку базы данных из-за перегрузки вебсервера.

Remark: Да, купили KVM VDS готовим его для переноса, но это не получается сделать быстро.

 

Техподдержка пишет что проблема в этих запросах:

SELECT * FROM oc_product p LEFT JOIN oc_product_description pd ON (p.product_id = pd.product_id) WHERE pd.language_id = '1' GROUP BY p.product_id ORDER BY pd.name ASC;

SELECT p.product_id, p.quantity>0 as instock, (SELECT AVG(rating) AS total FROM oc_review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT price FROM oc_product_discount pd2 WHERE pd2.product_id = p.prod

 

Есть ли возможность как-то оптимизировать БД? Хотя бы как временное решение, что бы неделю прожить...

Может индексы создать какие-то?

По первому запросу - его надо переписать и частично индексы помогут

по второму запросу нужно избавляться от p.quantity>0 as instock, а делать предвычисляемое поле instock в таблице

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.