日期:2014-05-17  浏览次数:20426 次

如何传一个参数找出在标示表中存在3条或0记录的视频记录? 有查询示例SQL 谢谢

SELECT     Guid
FROM         Pub_Video
WHERE     EXISTS
                          (SELECT     Guid
                            FROM          Pub_Marking
                            WHERE      (MKGuid = Pub_Video.Guid)
                            GROUP BY Guid
                            HAVING      (COUNT(Guid) = 1))

以上SQL是查询出
找出在标示表中存在1条记录的视频记录?
但是现在我想找出在标示表中存在0条的记录的话
我把(COUNT(Guid) = 1)改为(COUNT(Guid) = 0)
是不行的,但我又不想用Not Exists主查询
要怎么办呢?
也就是相当于,整条SQL只有查询的记录数的值是可变的,其他不可变
然后要实现查询:
找出在标示表中存在"0|1|2|3”条记录的视频记录?

谢谢




------解决方案--------------------
SELECT?????Guid
FROM?????????Pub_Video
WHERE?????EXISTS
??????????????????????????(SELECT?????Guid
????????????????????????????FROM??????????Pub_Marking
????????????????????????????WHERE??????(MKGuid?=?Pub_Video.Guid)
????????????????????????????GROUP?BY?Guid
????????????????????????????HAVING??????(COUNT(Guid)?<?1))
------解决方案--------------------
说实在的,我感觉用Not Exists就行了后面改下用HAVING      (COUNT(Guid)>0))
------解决方案--------------------
子项可以继续加啊,有什么问题呢?
------解决方案--------------------
DECLARE @cnt INT