IF OBJECT_ID(N'a') IS NOT NULL DROP TABLE a
CREATE TABLE a
(id INT NOT NULL,
NAME VARCHAR(20),
class VARCHAR(20),
COUNT INT,
date DATETIME
)
INSERT INTO a VALUES ('1','苹果','水果',10,'2011-7-1'),('1','桔子','水果',20,'2011-7-2'),('1','香蕉','水果',15,'2011-7-3')
INSERT INTO a VALUES('2','白菜','蔬菜',12,'2011-7-1'), ('2','青菜','蔬菜',19,'2011-7-2')
如果想要得到下面的结果:(Id唯一,Date选最近的一次)
1 香蕉 水果 15 2011-7-3
2 青菜 蔬菜 19 2011-7-2
语句如下:
SELECT * FROM A T
WHERE NOT EXISTS
(SELECT * FROM A WHERE id=t.id AND date>t.date)
注:NOT EXISTS 的作用与 EXISTS 正相反。如果子查询没有返回行,则满足 NOT EXISTS 中的 WHERE 子句。
即Exists做为WHERE条件时,是先对where前的主查询进行查询,然后用主查询的结果一个一个的代入exists的子查询进行判断,如果为真则输出当前这一条主查询的结果,否则不输出
Not Exists练习
最新推荐文章于 2023-07-05 15:52:29 发布