做兼职最好的网站有哪些,网络推广策划方案范文,腾讯云 wordpress建站,长沙 网站开发报价前两天去一家公司面试笔试#xff0c;技术部人员问到“SQL语句左联接与内连接的区别”。记得上大学时。在学校做“实训教学管理系统”中曾用过该语句#xff0c;印象中#xff0c;还和同组中同学有过争吵#xff08;技术上#xff09;呢。 因此#xff0c;当回答这道题时… 前两天去一家公司面试笔试技术部人员问到“SQL语句左联接与内连接的区别”。记得上大学时。在学校做“实训教学管理系统”中曾用过该语句印象中还和同组中同学有过争吵技术上呢。 因此当回答这道题时很咄咄有词一口气回答了下来本以为都回答对了。可今天接到回复复试名单中没有我很是失望又得找工作了。仔细回想下当时面试和笔试的题目今天特意验证了下那天的那些题才发现自己当时回答的很唐突片面。哎经济危机只是很小的一个原因关键是自己学识短浅没有工作经验和很强的能力。 如表 ------------------------------------------------- table1 | table2 | ------------------------------------------------- id name |id score | 1 lee |1 90 | 2 zhang |2 100 | 4 wang |3 70 | ------------------------------------------------- 以下均在查询分析器中执行 一、外连接 1.概念包括左向外联接、右向外联接或完整外部联接 2.左连接left join 或 left outer join (1)左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行则在相关联的结果集行中右表的所有选择列表列均为空值(null)。 (2)sql语句 select * from table1 left join table2 on table1.idtable2.id -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 2 100 4 wang NULL NULL ------------------------------ 注释包含table1的所有子句根据指定条件返回table2相应的字段不符合的以null显示 3.右连接right join 或 right outer join (1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行则将为左表返回空值。 (2)sql语句 select * from table1 right join table2 on table1.idtable2.id -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 2 100 NULL NULL 3 70 ------------------------------ 注释包含table2的所有子句根据指定条件返回table1相应的字段不符合的以null显示 4.完整外部联接:full join 或 full outer join (1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时则另一个表的选择列表列包含空值。如果表之间有匹配行则整个结果集行包含基表的数据值。 (2)sql语句 select * from table1 full join table2 on table1.idtable2.id -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 2 100 4 wang NULL NULL NULL NULL 3 70 ------------------------------ 注释返回左右连接的union见上左、右连接 二、内连接 1.概念内联接是用比较运算符比较要联接列的值的联接 2.内连接join 或 inner join 3.sql语句 select * from table1 join table2 on table1.idtable2.id -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 2 100 ------------------------------ 注释只返回符合条件的table1和table2的列 4.等价与下列执行效果相同 A:select a.*,b.* from table1 a,table2 b where a.idb.id B:select * from table1 cross join table2 where table1.idtable2.id (注cross join后加条件只能用where,不能用on) 三、交叉连接(完全) 1.概念没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。table1和table2交叉连接产生3*39条记录 2.交叉连接cross join (不带条件where...) 3.sql语句 select * from table1 cross join table2 -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 1 90 4 wang 1 90 1 lee 2 100 2 zhang 2 100 4 wang 2 100 1 lee 3 70 2 zhang 3 70 4 wang 3 70 ------------------------------ 注释返回3*39条记录即笛卡尔积 4.等价与下列执行效果相同 A:select * from table1,table2 [SQL脚本代码转自http://323229113.blog.163.com/blog/static/2185362820070172553209/ ]转载于:https://www.cnblogs.com/GT_Andy/archive/2008/11/04/1922118.html