sql >> Database teknologi >  >> RDS >> Mysql

Vil du vælge dubletter fra en enkelt række?

Dette ville få det omvendte (dvs. spring dubletterne over):

SELECT c1.*
  FROM CoreTracks c1
      ,(SELECT Title, ArtistID, MAX(FileSize) AS maxFileSize, MAX(BitRate) maxBitRate
          FROM CoreTracks
          GROUP BY Title, ArtistID) c2
  WHERE c1.Title = c2.Title
    AND c1.ArtistID = c2.ArtistID
    AND (c1.FileSize = c2.maxFileSize OR c1.BitRate = c2.maxBitRate)

Og dubletterne:

SELECT c1.*
  FROM CoreTracks c1
      ,(SELECT Title, ArtistID, MAX(FileSize) AS maxFileSize, MAX(BitRate) maxBitRate
          FROM CoreTracks
          GROUP BY Title, ArtistID) c2
  WHERE c1.Title = c2.Title
    AND c1.ArtistID = c2.ArtistID
    AND (c1.FileSize != c2.maxFileSize AND c1.BitRate != c2.maxBitRate)


  1. MySQL deaktiver og aktiver nøgler

  2. MySQL ukendt kolonne i ON-klausul

  3. Sådan hentes felt fra MySQL-forespørgselsresultat i bash

  4. SQL:Hjælp mig med at optimere min SQL