有如下的几个数据表:
CREATE TABLE 学生 (学生ID INT, 姓名 VARCHAR(20))
CREATE TABLE 课程 (课程ID INT, 课程名 VARCHAR(20))
CREATE TABLE 成绩表 (学生ID INT, 课程ID INT, 成绩 INT)INSERT INTO 学生
SELECT 1,'张三' UNION ALL
SELECT 2,'李四' UNION ALL
SELECT 3,'王五'INSERT INTO 课程
SELECT 1,'语文' UNION ALL
SELECT 2,'化学' UNION ALL
SELECT 3,'外语' UNION ALL
SELECT 4,'物理'INSERT INTO 成绩表
SELECT 1,1,60 UNION ALL
SELECT 1,2,70 UNION ALL
SELECT 1,3,65 UNION ALL
SELECT 1,4,90 UNION ALL
SELECT 2,1,80 UNION ALL
SELECT 2,2,65 UNION ALL
SELECT 2,3,85 UNION ALL
SELECT 2,4,80 UNION ALL
SELECT 3,1,50 UNION ALL
SELECT 3,2,75 UNION ALL
SELECT 3,3,85 UNION ALL
SELECT 3,4,60
表结构大家一看就知道了,
学生Id    姓名
1             张三
2             李四
3             王五
课程表:
课程Id    课程名
1             语文
2             化学
3             外语
4             物理
成绩表:
学生Id     课程Id        成绩
1               1                 60
1               2                 70
1               3                 65
1               4                 90
2               1                 80
2               2                 65
2               3                 85
2               4                 80
3               1                 50
3               2                 75
3               3                 85
3               4                 60
下面两个sql语句得到的结果是一样的,
语句一
select a.姓名,b.课程名,c.成绩 from 学生 a,课程 b,成绩表 c where a.学生id=c.学生id and b.课程id=c.课程id[/code.语句二[code=SQL]
SELECT B.姓名,C.课程名,D.成绩 FROM 成绩表 D 
INNER JOIN 学生 B ON B.学生ID=D.学生ID 
INNER JOIN 课程 C ON C.课程ID=D.课程ID
我的问题是:
1、两种写法有本质区别否?有的话区别在什么地方
2、有区别的话,那种写法更好理解,更科学,执行效率更高,

解决方案 »

  1.   

    Oracle inner join和where区别    1 .WHERE子句中使用的连接语句,在数据库语言中,被称为隐性连接。INNER JOIN……ON子句产生的连接称为显性连接。(其他JOIN参数也是显性连接)WHERE 和INNER JOIN产生的连接关系,没有本质区别,结果也一样。但是!隐性连接随着数据库语言的规范和发展,已经逐渐被淘汰,比较新的数据库语言基本上已经抛弃了隐性连接,全部采用显性连接了。  2 .无论怎么连接,都可以用join子句,但是连接同一个表的时候,注意要定义别名,否则产生错误!  > inner join:理解为“有效连接”,两张表中都有的数据才会显示left join:理解为“有左显示”,比如on a.field=b.field,则显示a表中存在的全部数据及a\\b中都有的数据,A中有、B没有的数据以null显示  > right join:理解为“有右显示”,比如on a.field=b.field,则显示B表中存在的全部数据及a\\b中都有的数据,B中有、A没有的数据以null显示  > full join:理解为“全连接”,两张表中所有数据都显示,实际就是inner +(left-inner)+(right-inner)  3 .join可以分主次表 外联接有三种类型:完全外联,左联,右联.  完全外联包含两张表的所有记录.  左联是以左边的表为主,右边的为辅,右联则相反  4.一般要使得数据库查询语句性能好点遵循一下原则:  在做表与表的连接查询时,大表在前,小表在后  不使用表别名,通过字段前缀区分不同表中的字段  查询条件中的限制条件要写在表连接条件前  尽量使用索引的字段做为查询条件
      

  2.   

    再问一下
    SELECT B.姓名,C.课程名,D.成绩 FROM 成绩表 D 
    INNER JOIN 学生 B ON B.学生ID=D.学生ID 
    INNER JOIN 课程 C ON C.课程ID=D.课程ID
    这个语句中
    B.学生ID=D.学生ID 
    换成
    D.学生ID=B.学生ID 
    结果相同,在效率上有区别么?
    或者写法上有什么注意的么?