Sqlserver
 sql >> Teknologi Basis Data >  >> RDS >> Sqlserver

SQL TIDAK DALAM kemungkinan masalah kinerja

Anda memiliki rangkaian kolom yang mencegah penggunaan indeks apa pun

Coba NOT EXISTS yang akan mendukung 2 kolom secara terpisah

SELECT distinct
     o.casino_id, g.game_id
FROM 
    game g 
    INNER JOIN 
    Bet b ON g.game_id = b.game_id
    INNER JOIN
    CasinoUser u ON b.user_id = u.user_id
    INNER JOIN
    onewalletcasino o  ON u.casino_id = o.casino_id
WHERE 
    game_start between dateadd(mi, -180, getdate()) 
                       and dateadd(mi, -5, getdate())  
    and
    b.[status] <> 'P'
    AND
    NOT EXISTS (SELECT *
           FROM 
              thirdpartysettlecalled   tp
           WHERE 
              tp.[status] = 'Y'
              AND
              tp.casino_id = o.casino_id AND tp.game_id = g.game_id)
ORDER BY
    casino_id 

Setelah itu, periksa indeks atau kursus Anda...

Ini adalah penggunaan yang baik dari KECUALI juga (ORDER BY berakhir seperti UNION:terima kasih kepada @Damien_The_Unbeliever)

SELECT distinct
     o.casino_id, g.game_id
FROM 
    game g 
    INNER JOIN 
    Bet b ON g.game_id = b.game_id
    INNER JOIN
    CasinoUser u ON b.user_id = u.user_id
    INNER JOIN
    onewalletcasino o  ON u.casino_id = o.casino_id
WHERE 
    game_start between dateadd(mi, -180, getdate()) 
                       and dateadd(mi, -5, getdate())  
    and
    b.[status] <> 'P'

EXCEPT
SELECT tp.casino_id, tp.game_id
FROM thirdpartysettlecalled   tp
WHERE tp.[status] = 'Y'

ORDER BY
    casino_id



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Menggunakan Variabel dalam Query OPENROWSET

  2. Memperbarui 4 juta catatan di server SQL menggunakan daftar id catatan sebagai input

  3. Filter laporan Power BI berdasarkan pengguna saat ini

  4. SQL Server dan celah di kolom Identitas

  5. Cara ORDER BY di SQL PIVOT