从两种SQL表连接写法来了解过去

jinjazz 2009-08-08 02:10:27
加精
由朋友提出此类问题
http://topic.csdn.net/u/20090806/09/cd21b02c-e321-46d7-924a-82fd442b0a41.html

select * from a,b where a.id=b.id
select * from a inner join b on a.id=b.id

---这两个哪个好?

其中11楼的回答最为深入。其实这个问题还是有一定的历史原因的,不管你习惯什么样的写法只要知道来龙去脉就不会再被细枝末节来迷惑了。以下观点为个人认识,如有偏差欢迎指正。

简单的说,前者是ansi sql 86标准后者是ansi sql 92标准(*****),这个观点最容易被人接受。

什么是ansi?美国国家标准局,iso的重要成员之一,1918年就有了。
什么是ansi sql?就是ansi注意到了sql的生产力,于是规范化了一下。

什么是sql?他是ibm发明的,oracle发扬广大的一门语言。

为什么是两家公司?。
70年代初因为ibm内部各方利益斗争激烈,导致某大牛的研究成果只能以论文方式发表。
70年代末某小公司把此技术用在商业领域就成了oracle,直到n年后ibm db2才出来。

所以,sql不是ansi 发明的,ansi 标准也不能通吃所有数据库平台。

比如下面这个是什么数据库的语法?反正ansi 标准在他那里是报错的。
select * from (a inner join b on a.id=b.id) inner join c on a.id=c.id


那么在ansi86之前的数据库有哪些?oracle和db2是肯定的了。另外还有一些当时的小角色:Informix,dbase系列等。

而sybase的数据库和SQLServer是86年之后出来的,而前面那个奇怪的join语法的access是90后的。

古老的sqlserver和oracle我都没有用过,反正在02年用oracle8i时还不支持ansi 92的inner join,他是97年生的。一直到本世纪发布的oacle9i 才改了过来。用多了t-sql的人会问 left join咋办,where a.id=b.id(+) 就可以了,人家没那么笨的,t-sql以前还有*=这样的表示。


那么这么看貌似ansi的规范力度不够?其实不是,国际标准化也不可能一刀切,在ansi92 当中定义了4个级别,n多条款。大意就是大家符合入门级就行了,其他高级别仅供参考,甚至iso根本不会验证其他级别..而诸如inner join和left join之类的都是过渡级的,囧。


所以我前面打了5个星星的那句话并不是完全正确的,正确的应该是

前者符合ansi 86 标准和ansi 92入门级标准,后者符合ansi92 过渡级标准。

不是oracle8i不符合ansi92,而是没有符合ansi92的高级别规范,而完全实现高级别标准的数据库系统是没有的。

早在oracle7就已经完全符合ansi92了,当然是指入门级,而且他就是ansi92 的模版范例。

--回到上面的话题,这两个哪个好?
性能当然完全一样,区别只是习惯和喜好,但也因为标准级别不同而具有不同的风险。

如果想要优雅而易于维护且不容易写错的代码,当然用高标准的第二种方法。
如果必要考虑风险这个因素,比如涉及到多种平台的迁移或者整合,你应该用第一种,起码在两个表的情况下他还是比较安全的。

----
顺带提一句,ansi标准一直在修订:具体有多少版本就不列举了,我们得到的好处自然是多多的,比如递归、对象、数组、xml等等在各主流数据库的新版本中都陆续实现了
...全文
3621 171 打赏 收藏 转发到动态 举报
写回复
用AI写文章
171 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiao520bei 2009-10-02
  • 打赏
  • 举报
回复
学习了
伤神v 2009-09-02
  • 打赏
  • 举报
回复
join 的强大之处在于它提供了 left outer join, right outer join, full outer join 的用法.
传统方式无法达到
xupeihuagudulei 2009-08-19
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 herowang 的回复:]
db不留
[/Quote]
swetter_hundsun 2009-08-18
  • 打赏
  • 举报
回复
大公司都在制作标准,然后ANSI望风跟随,以现成标准制定国际标准
lirj770 2009-08-18
  • 打赏
  • 举报
回复
错了,应该是引用76楼的
lirj770 2009-08-18
  • 打赏
  • 举报
回复
[Quote=引用 75 楼 whzxl06018 的回复:]
不错不错!值得学习。
[/Quote]

select * from a,b where a.id=b.id
select * from a inner join b on a.id=b.id
两者区别在于 id字段显示次数等问题
我通常用后者,简洁!

还有
select * from (a inner join b on a.id=b.id) inner join c on a.id=c.id
与select * from a (inner join b on a.id=b.id) inner join c on a.id=c.id


select * from a (inner join b on a.id=b.id) inner join c on a.id=c.id这一句在access0不通过,是错误的。
还有两者区别在于 id字段显示次数等问题 ,在access下是没区别的,ID照样显示
szh3210 2009-08-18
  • 打赏
  • 举报
回复
up
永不言弃SUN 2009-08-14
  • 打赏
  • 举报
回复
了解
星星点灯6 2009-08-12
  • 打赏
  • 举报
回复
(*^__^*)...嘻嘻,这种情况公说公有理婆说婆有理,只要你能让人信服你就好楼
shuifengcun 2009-08-12
  • 打赏
  • 举报
回复
学习
zhbh 2009-08-12
  • 打赏
  • 举报
回复
顶!
Defonds 2009-08-12
  • 打赏
  • 举报
回复
学习
cwmwss 2009-08-12
  • 打赏
  • 举报
回复
不错的内容。
cqhweb 2009-08-12
  • 打赏
  • 举报
回复
好东东...
guyehanxinlei 2009-08-11
  • 打赏
  • 举报
回复
学习了
lw1a2 2009-08-11
  • 打赏
  • 举报
回复
路过
Eagle_ice 2009-08-11
  • 打赏
  • 举报
回复
强大...
wolcott2387 2009-08-11
  • 打赏
  • 举报
回复
学习了
懒猫 2009-08-11
  • 打赏
  • 举报
回复
好深入的研究,来学习接分的。感谢楼主分享。
我来看看CB 2009-08-11
  • 打赏
  • 举报
回复
学习。。。。
加载更多回复(148)

11,849

社区成员

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

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