Left Jion和where区别】的更多相关文章

首先,新建两张表A和B,然后插入6条数据到A表,3条数据到B表.语句如下: create table A( ID ,) not null, AName ) null ) create table B( ID ,) not null, BID int not null, BName ) null ) ) ) ) ) ) ) insert into A(AName) values(N'一班') insert into A(AName) values(N'二班') insert into A(ANam…
背景 在一次面试的时候,面试官让我说一下这三者的使用场景和区别,当时瞬间懵逼,哈哈.回来赶快看一看,记下来. 详解 inner join 等值查询:返回两张表中,联结字段值相等的组合记录 举例:所有学生参加考试,学生考试结果查询 表如下 表Student(学生表)记录如下: t_id name 1 龙 2 情 3 风 4 月 5 度 表Score(分数表)记录如下: c_id num t_id 1 50 1 2 88 2 3 90 3 4 62 4 5 0 5 查询语句:select s.t_i…
left jion   左联结 right jion 右联结 inner jion 等值联结 create table teacher( tid ) primary key auto_increment, tname ) not null, age int, phone ) )engine=INNODB /*插入信息*/ ,'); /* 哪些老师带课了*/ select distinct(t.tname) ,t.age from teacher t inner join course c on…
1.on是在生成临时表时()起作用,而且不管on中的条件是否为真,都会返回(left join)左边所有的数据,如果不匹配也是返回空. 2.where 是在生成了临时表后,再对表进行过滤 个人理解:先on后where,先通过on把所有数据生成临时表,where对临时表过滤. 有点深奥吗?来举个例子: 假设有两张表: 表1:tab1 id size 1 10 2 20 3 30 表2:tab2 size name   10 AAA 20 BBB 20 CCC 两条SQL语句: 1.select *…
数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户.       在使用left jion时,on和where条件的区别如下: 1. on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录. 2.where条件是在临时表生成好后,再对临时表进行过滤的条件.这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉.        假设有两张表: 表1 tab1: id size 1 10…
select * from td  left join (select case_id as sup_case_id , count(*) supervise_number from  td_kcdc_case_sup_info  group by  case_id  ) sup on     sup.sup_case_id = td.case_id where 1=1   /*不能去掉, 否则认为and 后的条件为 联合查询时的条件, 不能起过滤作用,由于left join因此td表中记录将全…
本文导读: 数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户.例如在使用left jion时,on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录:where条件是在临时表生成好后,再对临时表进行过滤的条件. on.where.having的区别 1.on.where.having这三个都可以加条件的子句中,on是最先执行,where次之,having最后.有时候如果这先后顺序不影响中间结果的话,那最终结果是相同的…
原文地址:http://hi.baidu.com/benben1006/blog/item/187deb77bc0e5319b151b974.html 数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户. 在使用left jion时,on和where条件的区别如下: 1. on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录. 2.where条件是在临时表生成好后,再对临时表进行过滤的条件.这时已经没有left jo…
1.slice(): Array和String对象都有 在Array中  slice(i,[j]) i为开始截取的索引值,负数代表从末尾算起的索引值,-1为倒数第一个元素j为结束的索引值,缺省时则获取从i到末尾的所有元素 参数返回:返回索引值从i到j的数组,原数组不改变 在String中 slice(i,[j]) 参数说明:i为开始截取的索引值,负数代表从末尾算起的索引值,-1为倒数第一个字符j为结束的索引值,缺省时则获取从i到末尾的所有字符 2.splice() 存在Array中     方法…
left join 和 left outer join 的区别 通俗的讲:    A   left   join   B   的连接的记录数与A表的记录数同    A   right   join   B   的连接的记录数与B表的记录数同      A   left   join   B   等价B   right   join   A          table   A:  Field_K,   Field_A    1                       a    3      …