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练习
猜你喜欢
转载自new-fighter.iteye.com/blog/1604267
今日推荐
周排行