sql中内联 和外联 区别
来源:互联网 发布:html写java代码 编辑:程序博客网 时间:2024/06/05 02:34
sql中内联 和外联 区别
这个概念一般看书不好理解。其实夜简单。有例子就简单了。
比如:
表A(主表)
cardid username
16 aa
23 bb
25 cc
29 dd
30 ee
表B(子表)
countid cardid score
1 16 34
2 25 300
3 29 1.5
在 cardid 列上联接 A 表和B 表。
分别用内联、外联试试。
内联:
SELECT cardid FROM A INNER JOIN B ON(A.cardid<>B.cardid)
那么这样查询就会交叉地拿A和B去比较,上例来说就是拿『16,23,25,29,30』和16,25,29比。那么显然<>的结果是:23,25,29,30,16,25,29,30。。。不符合我们的要求。因为内联本来就只有找相同的功能,没有找不同的功能。
左外联:
SELECT cardid FROM A LEFT OUTER JOIN B ON (B.cardid=A.cardid) WHEREB.cardid IS NULL
这里会拿左表(A)的所有行去和B比较,上例来说是『16,23,25,29,30』先和16比较,然后再和23比较。它将包括所有A表内容,而对应的B表,符合条件就打印,否则没有的话会为null。所以这样就按要求得到了为null的值,也就是缺少的。
右外联:
SELECT cardid FROM A RIGHT OUTER JOIN B ON (B.cardid=A.cardid)WHERE B.cardid IS NULL
这里会拿右表(B)的所有行去和A比较,上例来说是16,25,29和『16,23,25,29,30』比较。结果只包含B表的所有行。在这里显然不符合要求。
但SELECT cardid FROM B RIGHT OUTER JOIN A ON (B.cardid=A.cardid)WHERE B.cardid IS NULL是对的。事实上右外联都是通过转换为左外联实现的。
- sql中内联 和外联 区别
- sql中内联 和外联 区别
- sql 内联和外联
- sql 内联与外联区别
- SQL语句中的内联和外联
- sql 内联,外联
- 数据库外联和内联
- MS SQL和Access中使用函数的区别
- HTML中  和空格的区别
- SQL Union和SQL Union All用法
- sizeof 和 strlen区别
- x86 和 x64的区别
- memmove 和 memcpy的区别
- Delete 和 Truncate的区别
- SQL内联、外联的简单理解
- SQL 表连接,内联、外联、全连
- SQL内联、外联的简单理解
- SQL内联、外联的简单理解
- java Class类
- Hibernate Session的delete()方法
- Hibernate区分不同对象的方法
- Hibernate注解详细介绍
- Hibernate Annotation (…
- sql中内联 和外联 区别
- [IOS]AppDelegate.m
- windows7无法启动Telnet服务,出现…
- 连接Oracle数据库的Hibernate配置…
- ajax方法data参数用法的总结
- Linux系统下如何设置IP地址?
- linux ip地址自动获取,ip地址…
- linux命令配置IP详解
- Linux如何自动获取IP地址