left返回的是左连接结果,right 返回右连接结果,inner join返回的是迪卡尔积结果

解决方案 »

  1.   

    楼上的兄弟:cross join返回的是迪卡尔积结果
      

  2.   

    查询分析器-》帮助-》Transact-sql帮助,索引输入inner jion。
      

  3.   

    举个例子:
    假设a表和b表的数据是这样的。
    a            b 
    id  name  id  stock 
    1  a      1    15
    2    b      2    50
    3    c        select * from a inner join b on a.id=b.id
    这个语法是连接查询中的内连接,它产生的结果是
    两个表相匹配的记录出现在结果列表中。
    根据上面的表,出现的结果是这样的
    a.id  name  b.id  stock
    1    a      1    15
    2      b      2    50
    ----------------------------
    select * from a,b where a.id=b.id
    这个语法是内连接的另外一种写法,其执行结果与inner join 一样-------------------------------- select * from a left/right join b on a.id=b.id
    这个是外连接语法中的左外连接或右外连接
    如果是左外连接的话,它将显示a表的所有记录,
    select a.*,b.* from a left join b on a.id=b.id
    查询的结果是这样的:
    a.id  name  b.id  stock
    1     a    1      15
    2       b    2      50
    3       c   null    null 
    --------------------------------------------
    如果是右外连接的话,它将显示b表的所有记录,
    select a.*,b.* from a right join b on a.id=b.id
    查询的结果是这样的:
    a.id  name  b.id  stock
    1     a    1      15
    2       b    2      50