create table Student(S# varchar(10),Sname nvarchar(10),Sage datetime,Ssex nvarchar(10))
insert into Student values('01' , N'赵雷' , '1990-01-01' , N'男')
insert into Student values('02' , N'钱电' , '1990-12-21' , N'男')
insert into Student values('03' , N'孙风' , '1990-05-20' , N'男')
insert into Student values('04' , N'李云' , '1990-08-06' , N'男')
insert into Student values('05' , N'周梅' , '1991-12-01' , N'女')
insert into Student values('06' , N'吴兰' , '1992-03-01' , N'女')
insert into Student values('07' , N'郑竹' , '1989-07-01' , N'女')
insert into Student values('08' , N'王菊' , '1990-01-20' , N'女')
create table Course(C# varchar(10),Cname nvarchar(10),T# varchar(10))
insert into Course values('01' , N'语文' , '02')
insert into Course values('02' , N'数学' , '01')
insert into Course values('03' , N'英语' , '03')
create table Teacher(T# varchar(10),Tname nvarchar(10))
insert into Teacher values('01' , N'张三')
insert into Teacher values('02' , N'李四')
insert into Teacher values('03' , N'王五')
create table SC(S# varchar(10),C# varchar(10),score decimal(18,1))
insert into SC values('01' , '01' , 80)
insert into SC values('01' , '02' , 90)
insert into SC values('01' , '03' , 99)
insert into SC values('02' , '01' , 70)
insert into SC values('02' , '02' , 60)
insert into SC values('02' , '03' , 80)
insert into SC values('03' , '01' , 80)
insert into SC values('03' , '02' , 80)
insert into SC values('03' , '03' , 80)
insert into SC values('04' , '01' , 50)
insert into SC values('04' , '02' , 30)
insert into SC values('04' , '03' , 20)
insert into SC values('05' , '01' , 76)
insert into SC values('05' , '02' , 87)
insert into SC values('06' , '01' , 31)
insert into SC values('06' , '03' , 34)
insert into SC values('07' , '02' , 89)
insert into SC values('07' , '03' , 98)
go
下面sql語句的執行順序是怎樣的?誰能夠詳細解釋一下嗎?
select m.* , n.C# , n.score from Student m, SC n where m.S# = n.S# and n.score in 
(select top 3 score from sc where C# = n.C# order by score desc) order by n.C# , n.score desc
 

解决方案 »

  1.   

    顺序:
    from >  where> select> order by
      

  2.   

    先执行 select top 3 score from sc where C# = n.C# order by score desc再执行select m.* , n.C# , n.score from Student m, SC n where m.S# = n.S# and n.score in 最后order by
      

  3.   

    我的理解:是不是先from表Student,指針P1指向Student表第一條數據,接著from表SC,指針P2指向SC表的一條數據,然後where這時遇到in跳到子查詢語句中,接著from表sc,指針P3指向子查詢表sc的第一條數據+where),如果P3指針滿足條件的話,再回到主語句where,主語句where也滿足的話返回一條數據,就這樣循環下去;不知道我理解是否正確?來指點下我啊
    還有這條語句select m.* , n.C# , n.score from Student m, SC n where 是去笛卡而积吗?
      

  4.   

    怎樣才能查看執行計劃,是在SQL管理器中嗎
      

  5.   


    查询分析器里,用Ctrl+L,或者Ctrl+M,
    看计划就知道了