这应该有望使您朝着正确的方向前进-
//Gets rows where senderUID is the first (lowest TID) record in group
SELECT a.*
FROM test a
WHERE a.senderUID = '$receiverUID'
AND NOT EXISTS (select * from test where TCID = a.TCID and id < a.id and senderUID != '$receiverUID')
GROUP BY TCID
UNION
//Gets rows where senderUID is the same as the last receiverUID of TCID
SELECT b.*
FROM test b
WHERE b.receiverUID = '$receiverUID'
AND NOT EXISTS (select * from test where TCID = b.TCID and id > b.id and receiverUID != '$receiverUID')
GROUP BY TCID
所以作为一个简单的例子,我有下表 -
data:image/s3,"s3://crabby-images/e1d88/e1d884b94f22e075f6d12172f0d28bc3c7f5cebb" alt="表数据"
因此,如果我设置 $receiverUID = 1,我会得到 2 行,其中 senderUID 是 TCID 组 (1,9) 中的第一个,以及 3 行,其中 senderUID 是 TCID 组中的receiverUID (4,7,8)
data:image/s3,"s3://crabby-images/000ec/000ec4b67ff0878186be73fe8768ae1d9bd865ff" alt="senderUID/receiverUID 的 TCID 组为 1"
LIMIT 1
如果您只想获得 1 行,其中 senderUID 是 TCID 组 (1)/(4,7,8) 中的第一个,则可以添加
SELECT a.*
FROM test a
WHERE a.senderUID = '$receiverUID'
AND NOT EXISTS (select * from test where TCID = a.TCID and id < a.id and senderUID != '$receiverUID')
GROUP BY TCID LIMIT 1
data:image/s3,"s3://crabby-images/bb557/bb557aad1aafc83f329bdc6f8a8160d37419fe22" alt="senderUID/receiverUID 的 TCID 组为 1,仅限制第一行 senderUID"
同样的想法,如果我设置 $receiverUID = 2 (3,11)/(6,10)
data:image/s3,"s3://crabby-images/3c690/3c69075c74df5b76d3d5950460772b48ca42db0a" alt="senderUID/receiverUID 的 TCID 组为 2"
和LIMIT 1
(3)/(6,10)
data:image/s3,"s3://crabby-images/092ca/092ca498d5197eba3181a2374b4be8c7e63ebad8" alt="senderUID/receiverUID 的 TCID 组为 2,仅限制第一行 senderUID"