recherche

Maison  >  Questions et réponses  >  le corps du texte

Comparaison de la gestion des requêtes lentes MySQL dans une relation maître-détails entre deux tables : un guide étape par étape

S'il vous plaît, aidez-moi.. J'ai une requête comme celle-ci : Voici un tableau :

  1. delivery_order
  2. delivery_order_item
  3. bst
  4. bst_item

Je souhaite afficher les éléments qui existent dans la table delivery_order/item mais pas dans la table bst/item, en comparant en fonction de KODE_BARANG et JUMLAH.

J'ai l'instruction de requête suivante, mais elle est toujours très lente s'il y a déjà beaucoup de données (la partie lente compare les lignes de KODE_BARANG). Je voudrais demander si l'un de mes amis a une situation similaire et comment la résoudre ? Merci d'avance, j'espère que quelqu'un ici sera prêt à répondre.

SELECT
    del.KODE_DO,
    deli.KODE_BARANG,
    deli.NAMA_BARANG,
    deli.JUMLAH,
    deli.SATUAN,
    @DITERIMA := COALESCE ((
        SELECT
            SUM( JUMLAH ) 
        FROM
            bst_item 
        WHERE
            KODE_PENERIMAAN = deli.KODE_DO
            AND KODE_BARANG = deli.KODE_BARANG  #这行使它变慢
            AND `STATUS` <> 0),0) AS DITERIMA,
    COALESCE ( deli.JUMLAH, 0 ) - @DITERIMA AS SISA
FROM
    delivery_order del
    INNER JOIN delivery_order_item deli ON del.KODE_DO = deli.KODE_DO
WHERE
    DATE(del.TANGGAL) >= :TGL1
    AND DATE(del.TANGGAL) <= :TGL2  
    AND COALESCE ( deli.JUMLAH, 0 ) - COALESCE ((
        SELECT
            SUM( JUMLAH ) 
        FROM
            bst_item 
        WHERE
            KODE_PENERIMAAN = deli.KODE_DO
            AND KODE_BARANG = deli.KODE_BARANG  #这行使它变慢
            AND `STATUS` <> 0),0) > 0
SELECT
    del.KODE_DO,
    deli.KODE_BARANG,
    deli.NAMA_BARANG,
    deli.JUMLAH,
    deli.SATUAN,
    @DITERIMA := COALESCE ((
        SELECT
            SUM( JUMLAH ) 
        FROM
            bst_item 
        WHERE
            KODE_PENERIMAAN = deli.KODE_DO
            AND KODE_BARANG = deli.KODE_BARANG  #这行使它变慢
            AND `STATUS` <> 0),0) AS DITERIMA,
    COALESCE ( deli.JUMLAH, 0 ) - @DITERIMA AS SISA
FROM
    delivery_order del
    INNER JOIN delivery_order_item deli ON del.KODE_DO = deli.KODE_DO
WHERE
    DATE(del.TANGGAL) >= :TGL1
    AND DATE(del.TANGGAL) <= :TGL2  
    AND COALESCE ( deli.JUMLAH, 0 ) - COALESCE ((
        SELECT
            SUM( JUMLAH ) 
        FROM
            bst_item 
        WHERE
            KODE_PENERIMAAN = deli.KODE_DO
            AND KODE_BARANG = deli.KODE_BARANG  #这行使它变慢
            AND `STATUS` <> 0),0) > 0

P粉724256860P粉724256860495 Il y a quelques jours507

répondre à tous(1)je répondrai

  • P粉652523980

    P粉6525239802023-09-14 14:59:16

    INDEX(KODE_PENERIMAAN, KODE_BARANG, `STATUS`)

    Et ne cachez pas TANGGAL dans les appels de fonction. (cf "sargable")

    répondre
    0
  • Annulerrépondre