Not Exists练习

   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的子查询进行判断,如果为真则输出当前这一条主查询的结果,否则不输出 

猜你喜欢

转载自new-fighter.iteye.com/blog/1604267