2级VFP,SQL哪种情况下用 inner join .........on...... 语句

来源:百度知道 编辑:UC知道 时间:2024/06/20 09:29:02
主要跟一般的直接连起来有啥区别
有时候不是没有用这个语句啊~直接用逗号把表连起来了..主要是何种情况下用?何种情况下不用?

不知你说的用逗号连接是怎么回事,如果两个表要连接查询结果的话肯定要用到下面四种情况的一种。不是INNER JOIN的连接就是其他三种情况之一。
具体举个例子
SELECT a.xh, a.yw, b.xx FROM a INNER JOIN b ON a.xh =b.xh
其中a.xh, a.yw, b.xx是显示的结果中包含的字段,FROM a INNER JOIN b 是结果中的字段来自哪两个怎么关联的表,ON a.xh =b.xh是两个表关联的关键字段。这是最简单的两个表的连接查询,必须要有这三个基本内容。至于排序、分组等功能的实现再另外加条件就行了。
_____________________________
两表连接有四种情况:
INNER JOIN 只有在其他表中包含对应记录(一个或多个)的记录才出现在查询结果中。即JOIN左右两则所有的匹配记录。
LEFT [OUTER] JOIN 在查询结果中包含:JOIN 左侧表中的所有记录,以及JOIN 右侧表中匹配的记录。OUTER 关键字可被省略;包含 OUTER 强调这是一个外连接 (outer join)。
RIGHT [OUTER] JOIN 在查询结果中包含:JOIN 右侧表中的所有记录,以及 JOIN 左侧表中匹配的记录。OUTER 关键字可被省略;包含 OUTER 强调这是一个外连接接 (outer join)。
FULL [OUTER] JOIN 在查询结果中包含:JOIN 两侧所有的匹配记录,和不匹配的记录;包含 OUTER 强调这是一个外连接 (outer join)。
比如两表A为语文成绩,B为数学成绩,通过学号XH连接,显示A.XH,A.YW,B.XH,B.XX:
A: B:
xh yw xh xx
1 80 1 90
2 85 3 70
3 60 4 50
1)、inner join 的结果为
1 80