mysql - 从单行中选择重复项?

标签 mysql sqlite

这里我有一个名为 CoreTracks 的表:

+---------+-----------------+----------+----------+----------+---------+
| TrackId |       URI       | ArtistID |  Title   | FileSize | BitRate |
+---------+-----------------+----------+----------+----------+---------+
|  1      | /home/music/... |   234    | atune    |  8958223 |   192   |
|  2      | /home/music/... |   427    | goodsong |  6954373 |   192   |
|  3      | /home/music/... |   427    | goodsong |  4695698 |   128   |
|  4      | /home/music/... |   427    | goodsong |  5839962 |   160   |
|  5      | /home/music/... |   427    | goodsong |  4695698 |   128   |
|  6      | /home/music/... |   522    | another  |  3458859 |   128   |
+---------+-----------------+----------+----------+----------+---------+

我想要检索的是:

+---------+-----------------+----------+----------+----------+---------+
| TrackId |       URI       | ArtistID |  Title   | FileSize | BitRate |
+---------+-----------------+----------+----------+----------+---------+
|  3      | /home/music/... |   427    | goodsong |  4695698 |   128   |
|  4      | /home/music/... |   427    | goodsong |  5839962 |   160   |
|  5      | /home/music/... |   427    | goodsong |  4695698 |   128   |
+---------+-----------------+----------+----------+----------+---------+

我尝试根据具有相同的标题、相同的艺术家 ID 和不同的轨道 ID 来删除重复项,同时不返回具有最高比特率和最大文件大小的条目。

到目前为止我所拥有的是:

SELECT * FROM CoreTracks 
WHERE Title = Title AND ArtistID = ArtistID 
AND BitRate != (SELECT MAX(BitRate) FROM CoreTracks WHERE Title = Title AND ArtistID = ArtistID) 
AND FileSize != (SELECT MAX(FileSize) FROM CoreTracks WHERE Title = Title AND ArtistID = ArtistID);

返回每个轨道。为了让这个查询工作,我缺少什么?

最佳答案

这将得到相反的结果(即跳过重复项):

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)

以及重复项:

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)

关于mysql - 从单行中选择重复项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9881855/

相关文章:

mysql - Laravel 5.3 组查询构建器访问冲突

c# - 如何从 C# 中同一项目下的不同窗口窗体访问不同组件?

PHP 和 MySQL - 使用 mysqli_real_escape_string 的正确方法

mysql - 有没有什么好的方法检测MySQL是 "ready?"

python - 错误 :not all arguments converted during string formatting

iphone - SQLite 数据库复制

iphone - 来自 NSData 的 CGPDFDocumentRef

python - 从多个没有外键的表中选择数据?

ios - NSPredicate 搜索具有 nil 值的连接表

sqlite - 如何将 Sqlite 与 LiveCode 结合使用