20
Апр
2021

Вывод данных с трех таблиц (оптимизация)

Сделал простой запрос вывода с 3 таблиц mysql 5.6 Но он очень ужасно тормозит, в таблице tori 3гб, как можно оптимизировать? Сам запрос такой

SELECT card, pos, shift_open, local_number, 
       date, amount, tori.item, tori.quantity, 
       tori.receipt_header 
FROM trm_out_receipt_header torh   # к этой таблицы прикрепим две остальные по двум разным условиям совпадения
                                   # 2-ю таблицу по одному условию:
LEFT JOIN trm_out_receipt_item tori  ON (torh.id=tori.receipt_header) 
                                   # 3-ю по другому:
LEFT JOIN trm_out_receipt_payment torp ON (torh.id=torp.receipt_header) 
where torh.card IN ('229456', '229455') 
  and tori.cash_id in ('1005001', '1005004', '201002001', '201002005', '201002001', '201002003', '201002004', '201002005');

Висит очень долго и подскажите правильно ли я потом пытаюсь вывести? в дбфидл

<? while ($row = mysqli_fetch_assoc($result)) {
 echo " <tr><td> {$row['card']}</td>
 <td> {$row['pos']}</td>
 <td> {$row['shift_open']}</td>
 <td> {$row['local_number']}</td>
 <td> {$row['date']}</td>
<td>{$row['amount']}</td>
               <td>{$row['item']}</td>
               <td>{$row['quantity']}</td>
    ";

    
}

?>

Сделал так, но запрос очень долго идет, но все же выполняется, в таблице tori 3гб, как можно оптимизировать?

Можно ли сделать вывод двух полей в одну строку? смотрите

https://prnt.sc/11q5lyj

Explain

введите сюда описание изображения

Источник: https://ru.stackoverflow.com/questions/1272311/%D0%92%D1%8B%D0%B2%D0%BE%D0%B4-%D0%B4%D0%B0%D0%BD%D0%BD%D1%8B%D1%85-%D1%81-%D1%82%D1%80%D0%B5%D1%85-%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86-%D0%BE%D0%BF%D1%82%D0%B8%D0%BC%D0%B8%D0%B7%D0%B0%D1%86%D0%B8%D1%8F

Тебе может это понравится...

Добавить комментарий