请教inner join 与一般笛卡尔积的区别,如select * from tb1 a inner join tb2 b on a.id=b.id 与select * from tb1 a ,tb2

inner join 与一般笛卡尔积的区别:inner join是笛卡尔积的特殊形式。如果有表a和表b,表a有m条记录,表b有n条记录,则一般笛卡尔积后得到的记录条数是m*n条,记录之间的组合是随意的。而内连接则是建立在表a和表b的结构中有相同的列名的基础上进行的。

select * from tb1 a inner join tb2 b on a.id=b.id 与select * from tb1 a ,tb2 b where a.id=b.id 有什么不同?
第一条和第二条SQL语句的执行方式应该是不一样的。第一条的话应该是参照表a中的记录,一条一条到表b中去找符合记录的,符合则连在一起,否则转到a中下一条。
而第2条语句的执行方式是将表a和表b的记录组合起来,然后考察满足条件的,并返回。

你可能感兴趣的:(sql)