表关联的重新思考

99归一 2012-04-01 02:45:04
不好意思,今天押宝,把所有的分都压了,快船没有让我失望,胜利了,不过,押宝现在还没有结贴,本人属于裸奔状态,等结贴了一定补上。
在之前的T-SQL学习过程中,表关联一直使用了join用于表关联,很少或者说几乎不用在where 中进行表关联,自己以为用inner join 进行内连接,与在where 中进行连接执行出的结果是一样的,不过在执行顺序上不同而已,今天写了段SQL,居然出了不同的结果,具体的代码,测试结果如下,不知道大家有没有遇到过我这样的问题,通过这样的问题,让我重新审视了这两种不同的关联,希望大大们能够解答疑惑?

--说明:本人测试数据引用了大乌龟:一个项目涉及到的50个Sql语句
--1.学生表
Student(S#,Sname,Sage,Ssex) --S# 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别
--2.课程表
Course(C#,Cname,T#) --C# --课程编号,Cname 课程名称,T# 教师编号
--3.教师表
Teacher(T#,Tname) --T# 教师编号,Tname 教师姓名
--4.成绩表
SC(S#,C#,score) --S# 学生编号,C# 课程编号,score 分数
*/
--创建测试数据
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

--执行语句如下:
--1,主查询中不使用,子查询中不使用
select
Student.*
from Student , SC
where Student.S = SC.S and SC.C = '01'
and not exists (Select 1 from SC SC_2
where SC_2.S = SC.S and SC_2.C = '02')
order by Student.S

结果:
S Sname Sage Ssex
---------- ---------- ----------------------- ----------
06 吴兰 1992-03-01 00:00:00.000 女

(1 行受影响)

--2,主查询中使用,子查询中使用
select
Student.*
from
Student
inner join SC on Student.S = SC.S
where
SC.C = '01'
and not exists (Select 1 from SC SC_2 inner join sc on SC_2.S = SC.S
where SC_2.C = '02')
order by Student.S

--结果:
S Sname Sage Ssex
---------- ---------- ----------------------- ----------

(0 行受影响)

--3,主查询中使用,子查询中不使用
select
Student.*
from
Student
inner join SC on Student.S = SC.S
where
SC.C = '01'
and not exists (Select 1 from SC SC_2
where SC_2.S = SC.S and SC_2.C = '02')
order by Student.S

--结果:
S Sname Sage Ssex
---------- ---------- ----------------------- ----------
06 吴兰 1992-03-01 00:00:00.000 女

(1 行受影响)
--4,主查询中不使用 ,子查询中使用
select
Student.*
from Student , SC
where Student.S = SC.S and SC.C = '01'
and not exists (Select 1 from SC SC_2 inner join sc on SC_2.S = SC.S
where SC_2.C = '02')
order by Student.S
--结果:
S Sname Sage Ssex
---------- ---------- ----------------------- ----------

(0 行受影响)
...全文
91 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
ether030 2012-04-02
  • 打赏
  • 举报
回复
个人觉得查询的逻辑很重要,就是算法!

代码不同,算法可能不同。
--小F-- 2012-04-01
  • 打赏
  • 举报
回复
.
zhouixi 2012-04-01
  • 打赏
  • 举报
回复
哈哈,表语句不一样
灬重来灬 2012-04-01
  • 打赏
  • 举报
回复
帮忙顶个!群里
  • 打赏
  • 举报
回复
恭喜恭喜
99归一 2012-04-01
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 的回复:]
蛋贴没人回复
[/Quote]
你懂的!押宝压了!分还没给呢
  • 打赏
  • 举报
回复
蛋贴没人回复

11,849

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 非技术版
社区管理员
  • 非技术版社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧