Здравствуйте Гость [ Вход | Регистрация ] | Форум в сети 7055-й день

Шановні користувачі! Запрошуємо вас до офіційного телеграм-канала 0day Community. Тут ви зможете поспілкуватися одне з одним та дізнатися про останні новини щодо роботи ресурса, поставити запитання до адміністрації, тощо. Перейти до телеграм-канала можна відсканувавши QR-код або натиснувши на посилання: @zeroday_ua

 помогите оптимизировать SQL запрос, mysql

Navern
Jun 25 2018, 17:33
  
Пост #1



Репутация:   552  
Aut vincere , aut mori
****

Группа: Пользователи
Сообщений: 2 861
С нами с: 10-October 06


Добрый день. Нужно оптимизировать данный SQL запрос.


SELECT
    `transaction`.*
FROM
    `transaction`
    LEFT JOIN `transaction_2` ON `transaction`.`id` = `transaction_2`.`transaction_id`
WHERE
    transaction.deleted IS NULL
    AND
    (SELECT SUM(summ) FROM transaction_2 WHERE transaction_id = transaction.id) IS NULL
    OR transaction.summ - (SELECT SUM(summ) FROM transaction_2 WHERE transaction_id = transaction.id) <> 0


Удалось немного улучшить показатели, но не сильно.


SELECT
  transaction.id,
  transaction.summ,
  SUM(transaction_2.summ)
FROM transaction
LEFT JOIN transaction_2 ON transaction.id = transaction_2.transaction_id
WHERE transaction.deleted IS NULL
GROUP BY transaction.id
HAVING SUM(transaction_2.summ) IS NULL OR SUM(transaction_2.summ) <> transaction.summ


Кто-то может помочь? blush.gif
User is offlineProfile CardPM
Go to the top of the page
+Quote Post
 
Reply to this topicStart new topic
Ответов
revolver
Jun 25 2018, 19:13
  
Пост #2



Репутация:   1338  
ultra active user
******

Группа: BANNED
Сообщений: 33 534
С нами с: 2-June 08


тут особо нечего оптимизировать
убедись, что колонки id в обеих таблицах это pk (primary key), желательно кластерный
если нет и нельзя кластерный - построй некластерный (уникальный, если данные позволяют) по id с инклюдом summ, а на первой таблице - +deleted
запрос можно написать и так, но это те же яйца, только в профиль
WITH
  A AS (SELECT id, summ FROM transaction WHERE deleted IS NULL),
  B AS (SELECT id, SUM(summ) summ FROM transaction_2 GROUP BY id)
SELECT A.id, A.summ, B.summ FROM A LEFT JOIN B ON A.id=B.id AND (B.summ IS NOT NULL OR A.summ<>B.summ);


или так:
WITH
  A AS (SELECT id, summ FROM transaction WHERE deleted IS NULL),
  B AS (SELECT id, SUM(summ) summ FROM transaction_2 WHERE SUM(summ) IS NOT NULL GROUP BY id)
SELECT A.id, A.summ, B.summ FROM A LEFT JOIN B ON A.id=B.id AND A.summ<>B.summ;


Сообщение отредактировал revolver - Jun 25 2018, 19:14
User is offlineProfile CardPM
Go to the top of the page
+Quote Post
Navern
Jun 25 2018, 19:27
  
Пост #3



Репутация:   552  
Aut vincere , aut mori
****

Группа: Пользователи
Сообщений: 2 861
С нами с: 10-October 06


(revolver @ Jun 25 2018, 20:13) Перейти к цитате

убедись, что колонки id в обеих таблицах это pk (primary key), желательно кластерный


это сделано, но не решает проблему скорости sad.gif

а WITH с какой версией MYSQL работает?
User is offlineProfile CardPM
Go to the top of the page
+Quote Post

Сообщения в этой теме


Reply to this topicStart new topic

 



- Упрощённая версия
Сейчас: 8th July 2025 - 21:36
Сайт не розміщує електронні версії творів, а займається лише колекціонуванням та каталогізацією посилань, що публікуються нашими користувачами. Якщо Ви є правовласником якоїсь частини опублікованого матеріалу та не бажаєте, щоб посилання на нього знаходилось в нашому каталозі, зв’яжіться з нами і ми видалимо його. Файли для обміну надані користувачами сайту і адміністрація не несе відповідальності за їх вміст.