连接类型: 有不同类型的连接,包括内连接(INNER JOIN)、左外连接(LEFT JOIN 或 LEFT OUTER JOIN)、右外连接(RIGHT JOIN 或 RIGHT OUTER JOIN...2.3 内连接的实际应用场景 内连接在实际应用中有许多场景,特别是在需要检索两个或多个表中相互关联的数据时。...左外连接 (Left Outer Join): 定义: 左外连接返回左边表的所有行以及与右边表匹配的行。如果右边表中没有匹配的行,那么结果集中右边表的列将包含 NULL 值。...示例: SELECT * FROM table1 LEFT JOIN table2 ON table1.column = table2.column; 结果集: 结果包括左表的所有行,以及右表中与左表匹配的行...谨慎使用全外连接: 全外连接可能导致结果集庞大,确保在使用全外连接时真正需要保留所有行。
二、concat的基本用法(一)概述concat函数用于沿着一个特定的轴(行或列)将多个Pandas对象(如DataFrame或Series)连接在一起。...how:指定合并的方式,常见的有'inner'(内连接)、'outer'(外连接)、'left'(左连接)、'right'(右连接)。on:指定用于合并的列名,当左右两侧的列名相同时使用此参数。...left_on和right_on:当左右两侧用于合并的列名不同时,分别指定左右两侧的列名。suffixes:当存在重名列时,给左右两侧的列添加后缀以区分。...how='left')print("\n左连接结果:")print(left_result)# 右连接right_result = chinese_scores.merge(math_scores, on...对于concat,当join='outer'时,如果不同对象之间的索引不完全一致,可能会导致结果中出现NaN值。可以通过检查索引的一致性或者调整join参数来解决。
( out join ) 左连接(LEFT JOIN) 右连接 ( RIGHT JOIN) 内连接查询 INNER JOIN内连接 在表中至少一个匹配时,则返回记录 SELECT 字段1,字段2,...在自连接查询中,要先在FROM字句中为表分别定义两个不同的别名, 然后使用这两个别名写出一个连接条件。...分组的依据字段可以有多个,并依次分组 与HAVING结合使用,进行分组后的数据筛选 总结: 分析题目 1.分析题目 2.找出这个题目相关的表 3.找出这几个表之间的联系 4.分析顺序分析是不是要内连还是外连...5.看看查出来的结果跟你想象的是不是差不多 6.自己去做10条数据,看看结果是不是达到需求了 分析错误 如果你觉得结果出来了不满足你的预期一般有一下几种原因 0.内外连接使用是否恰当 1.外连顺序 2....多表连接的层级 3.分组把空值自动忽略 4.不要是自己骗自己,不要去函数凑数据
字符串函数 SUBSTRING函数 SUBSTRING函数用于截取字符串的一部分。...; CONCAT_WS函数 CONCAT_WS函数用于将多个字符串连接在一起,并以指定的分隔符分隔各个字符串。...例如,将students表中的first_name和last_name列用空格连接在一起,并以逗号分隔各个姓名: SELECT CONCAT_WS(', ', CONCAT(first_name, '...', last_name)) AS full_name FROM students; LEFT函数 LEFT函数用于截取字符串的左边指定长度的部分。...例如,将students表中的id列左对齐,并在左边用0填充: SELECT LPAD(id, 5, '0') FROM students; RPAD函数 RPAD函数用于将字符串右对齐,并在右边填充指定长度的字符
,查询结果如下: 二、内连接(INNER JOIN) 内连接(INNER JOIN):有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行。...三者的共同点是都返回符合连接条件和查询条件(即:内连接)的数据行。不同点如下: 左外连接还返回左表中不符合连接条件单符合查询条件的数据行。 右外连接还返回右表中不符合连接条件单符合查询条件的数据行。...全外连接实际是上左外连接和右外连接的数学合集(去掉重复),即“全外=左外 UNION 右外”。 说明:左表就是在“(LEFT OUTER JOIN)”关键字左边的表。右表当然就是右边的了。...下面总结一下两表连接查询选择方式的依据: 1、 查两表关联列相等的数据用内连接。 2、 Col_L是Col_R的子集时用右外连接。 3、 Col_R是Col_L的子集时用左外连接。...20.在使用索引字段作为条件时,如果该索引是复合索引,那么必须使用到该索引中的第一个字段作为条件时才能保证系统使用该索引,否则该索引将不会被使用,并且应尽可能的让字段顺序与索引顺序相一致。
LEFT OUTER JOIN 与左连接相同。箭头语法(->)还执行左外部联接。 RIGHT OUTER JOIN 与右连接相同。 FULL OUTER JOIN 与FULL JOIN相同。...单向外部连接是将第一个(源)表的行与第二个表的行链接在一起的连接,包括第一个表的所有行,即使第二个表中没有匹配。 这将导致第一个(源)表的某些字段可能与NULL数据配对。...在指定单向外部连接时,在FROM子句中命名表的顺序非常重要。 对于LEFT OUTER JOIN,指定的第一个表是该连接的源表。...ON 子句 内连接、左外连接、右外连接或全外连接都可以有ON子句。 ON子句包含一个或多个条件表达式,用于限制连接操作返回的值。 带有ON子句的连接可以在连接表达式中的任何位置指定。...例如,查询SELECT * FROM t1,t2 JOIN t3 ON t1.p1=t3.p3失败,因为t1和t3不是join的操作数; t1连接t2 JOIN t3的结果集。
选择性:选择性是指索引列中不同值的数量与表中记录数的比率。选择性高的列(即列中有很多唯一的值)更适合创建索引。...代替OR时,还需要注意查询语句的语义是否与原始查询相同。...要选用正确的关联方式,确保查询内容的正确性。INNER JOIN(内连接):内连接返回满足连接条件的行,即两个表中相关联的行组合。只有在两个表中都存在匹配的行时,才会返回结果。...sql复制代码SELECT *FROM table1INNER JOIN table2 ON table1.column = table2.column;LEFT JOIN(左连接):左连接返回左侧表中的所有行...使用 JOIN 可以将多个表连接在一起,使我们能够根据关联的列获取相关的数据,并更有效地处理复杂的查询需求。
连接-join 点连接、join连接、子查询 子查询:内层查询结果作为外层的比较条件。...一般子查询都可以转换成连接,推荐使用连接。 子查询清晰方便,但性能上存在一定劣势,不利于mysql查询优化器优化。...连接主要通过嵌套循环的方式实行的,mysqly查询优化器会自行将小的作为外层表,大的作为内层表,但子查询是定死的。 left join 从坐标中返回所有的行,即使右表中没有匹配到行。...与left join对应的是right join关键字,会返回右表中所有的行,即使左表中没有匹配的行。 union 不同表中相同的字段聚合在一个结果集中返回。...order by/distinct/group by having(聚合函数)/like(%前后缀) 连接语法 内连接、左连接、右连接、Union[all] DML进阶语法 insert/连表update
摘要 关于这两种写法的重要知识点摘要如下: left-join 时,即使有相同的查询条件,二者的查询结果集也不同,原因是优先级导致的,on 的优先级比 where 高 on-and 是进行韦恩运算连接生成临时表时使用的条件...这两种写法有什么区别 两者放置相同条件,之所以可能会导致结果集不同,就是因为优先级。on的优先级是高于where的。...在left join下,两者的区别: on是在生成临时表的时候使用的条件,不管on的条件是否起到作用,都会返回左表 (tb_user) 的行。...where则是在生成临时表之后使用的条件,此时已经不管是否使用了left join了,只要条件不为真的行,全部过滤掉。 在多表查询时,on 比 where 更早起作用。...第三步:分析执行过程及结果 根据执行过程,从上述执行结果可以看出: 这2个SQL语句的执行结果完全不同,使用时需要注意 两者放置相同条件,之所以可能会导致结果集不同,就是因为优先级:on的优先级是高于where
---- 连接(JOIN)简介 内连(INNER JOIN) INNER JOIN 关键字在表中存在至少一个匹配时返回行。...左连接(LEFT JOIN) LEFT JOIN 关键字从左表(table1)返回所有的行,即使右表(table2)中没有匹配。如果右表中没有匹配,则结果为 NULL。...如果左表中没有匹配,则结果为 NULL。 **注:**右连接可以理解成左连接的对称互补,详细说明可参见左连接。...where,这个与内连接在有条件限制的情况下是一样的,其维恩图也可以一并参考。...这个时候,我们就需要通过外连接中的左连接(如果采用右连接,那么相应的表位置也要进行替换)来进行查询了。在左连的查询中,因为是包含了”左表“的全部行,所以对于未选出班长的303来说,这个很有必要。
二 连接方式 ---- ? how: 指定合并时使用的连接方式,连接方式有四种,默认为left。...inner 内连 取行索引的交集 outer 外连 取行索引的并集 left 左连 使用左边df的行索引 right 右连 使用右边df的行索引 三设置用于连接的列 ---- ?...on: 指定合并时调用join()方法的DataFrame中用于连接(外连,内连,左连,右连)的列。默认为None,join()方法默认是使用行索引进行连接。...观察上面的例子,left1中有key列,而right1中没有key列,不过right1的行索引可以与left1的key列可以进行匹配,用左连接的方式得到结果。这个结果相当于如下的merge()操作。...合并多个DataFrame时,只支持用DataFrame的行索引进行连接,不能使用on参数。默认使用的是左连接,可以设置成其他的连接方式。
SQL优化过程中,发现开发人员在写多表关联查询的时候,对于谓词过滤条件的写法很随意,写在on后面与where后面的情况均有,这可能会导致没有理解清楚其真正的含义而无法得到期望的结果。...多表关联连接方式有inner join、left join、right join、full join四种,下面通过实验来说明不同连接方式谓词放在on与where后的效果与影响。...这是由left join的特性决定的,左表会显示全部数据。t2.id连接,而t1.status=’1’是作为连接条件存在,对连接时产生的笛卡尔积数据做连接过滤。...on后面,先对两表进行过滤,再进行left join,显示结果集与写在where后面是不同的,连接方式还是左外连接,显示t1过滤后的全部数据。...3.对于外连接,谓词条件放的位置不同,结果集也不同,可以根据自己的需求斟酌使用。
略 full join 全连接 full join 略 left semi join 左半连接 只显示左表中的记录。...左半连接与左外连接的区别是,左半连接将返回左表中符合 join 条件的记录,而左外连接将返回左表所有的记录,匹配不上 join 条件的记录将返回 null 值。... = course_info.courseId 隐式连接 与内连接功能相同,返回两表中满足 where 条件的结果集,但不用 join 显示指定连接条件 select student_info.name...使用 udf 函数进行业务内复杂结构字段提取 -- parse_components 就是业务种自定义的 udf 函数,用来解析一个复杂得动态字段,此字段根据不同的模板可能出现得字段枚举超过百种 select...使用递归创建一个连续无限时间戳表 和上面的增量表关联做左连接,如果数据行为空的时候,使用错位窗口 leg/lead 函数补齐 不使用窗口函数的方案(复杂一点不推荐,使用老版本 mysql 不支持窗口时候可以用
inner内连取key列的交集outer外连取key列的并集left左连使用左边df的key列right右连使用右边df的key列 三指定连接的列 ---- ?...on: 指定合并时用于连接(外连,内连,左连,右连)的列。...right_on: 指定第二个DataFrame中用于连接的列,默认为None。 当left_on和right_on都指定一样的列时,与用on参数的结果一样。...如果left_on和right_on指定不同的列,可能因为连接列的值匹配不上,结果是一个空DataFrame,将连接方式改成outer后才能得到非空的DataFrame。 ?...left_on和right_on可以与left_index和right_index混合使用,当指定了其中一个DataFrame的连接列时,必须同时指定另一个DataFrame的连接列,否则会报错。
其中,mid(), substr() 等价于 substring() 函数,substring() 的功能非常强大和灵活。 left(str, length) ?...JOIN 按照功能大致分为如下三类: INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。...**LEFT JOIN(左连接):**获取左表所有记录,即使右表没有对应匹配的记录。...RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。...---- LEFT JOIN left join 与 join 有所不同。 LEFT JOIN 会读取左边数据表的全部数据,即便右边表无对应数据。
表关联类型 常见的表关联类型有四种,内连接(INNER JOIN)、左外连接(LEFT OUTER JOIN)、右外连接(RIGHT OUTER JOIN)、全外连接(FULL OUTER JOIN...左外连接(LEFT OUTER JOIN),OUTER通常可以省略不写,它的含义是,左右两个集合相乘后,保留满足ON后面关联条件的记录加上左表中原有的但未关联成功的记录。...右外连接(RIGHT OUTER JOIN),与左外连接含义相同,只是方向不同而已,通常也是省略OUTER不写。...使用UNION可能会导致记录数的减少,在使用聚合函数时,可能会导致计算出现偏差 b. 在使用1对多或多对多关系的表进行关联时,记录数可能会增多,也可能会导致计算出现偏差 c. ...左外连接和右外连接都有连接方向的问题,表放的位置对结果是有影响的,尤其是多表关联时,一定要关注书写的顺序,尽可能先做内连接再做左/右外连接。 d.
MySQL的关联查询语句 六种关联查询 交叉连接(CROSS JOIN) 内连接(INNER JOIN) 外连接(LEFT JOIN/RIGHT JOIN) 联合查询(UNION与UNION ALL)...没有任何关联条件,结果是笛卡尔积,结果集会很大,没有意义,很少使用 内连接(INNER JOIN) SELECT * FROM A,B WHERE A.id=B.id或者 SELECT * FROM A...A.id > B.id 自连接:SELECT * FROM A T1 INNER JOIN A T2 ON T1.id=T2.pid 外连接(LEFT JOIN/RIGHT JOIN) 左外连接:LEFT...OUTER JOIN, 以左表为主,先查询出左表,按照ON后的关联条件匹配右表,没有匹配到的用NULL填充,可以简写成LEFT JOIN 右外连接:RIGHT OUTER JOIN, 以右表为主,先查询出右表...如果在 where 子句中使用参数,也会导致全表扫描。因为SQL只有在运行时才会解析局部变量,但优化程序不能将访问计划的选择推迟到运行时;它必须在编译时进行选择。
连接操作关键字CROSS JOIN:笛卡尔积,返回两个表的所有可能组合。INNER JOIN:内连接,只返回两个表中匹配的行。...LEFT JOIN 或 LEFT OUTER JOIN:左外连接,返回左表的所有行,右表中匹配的行。...RIGHT JOIN 或 RIGHT OUTER JOIN:右外连接,返回右表的所有行,左表中匹配的行。FULL JOIN 或 FULL OUTER JOIN:全外连接,返回两个表中不匹配的行。...SUBSTRING:用于提取字符串的一部分。数学函数关键字ABS:返回数值的绝对值。ROUND:四舍五入到指定的小数位数。CEILING 或 CEIL:向上取整。FLOOR:向下取整。...HOST:指代用户连接的主机。其他关键字AS:用于重命名列或表的别名。BY:与GROUP BY或ORDER BY一起使用。USING:用于指定多个表之间的公共列。ON:用于指定连接条件。
2.1表与表之间存在的关系 (1)一对多:在多的一方添加外键列 (2)多对多:需要创建一个中间表,该表中至少有两个外键列 2.2连表查询 2.3内连接 内连接演示—结果都是一样,只是语法不同。...-- 连表查询时,如果不使用连表条件则出现笛卡尔集。...) –2.查询dept表的所有数据,和对应的员工信息(右外连接) -- 语法: select 查询列集 from A表 left join B表 on 连表条件 -- 1.查询emp表的所有数据, 和对应的部门信息...(左外连接) select * from tb_emp e left outer join tb_dept d on e.dept_id = d.id; select * from tb_emp e left...(2)查询所有员工 emp及其领导的名字emp ,如果员工没有领导,也需要查询出来 -- 1.查询员工及其所属领导的名字。你要查询的结果再一张表中,但是还不能使用单表查询得到结果。
常见的 MySQL 内置函数 与之对应,还有多行处理函数,前者是说有一条输入,对应一条输出结果;后者则是多行输入,对应一条输出结果,比如:求和函数sum() 。...SQL查询分类 根据SQL语法年代 SQL92:1992年出现的语法 SQL99:1999年出现的语法 根据表连接的方式 内连接 等值连接 非等值连接 自连接 外连接 左外连接(左连接) 右外连接(右链接...对应左连接查询SQL: select e.ename, d.dname from dept d left join emp e on e.deptno = d.deptno; 总结: 外连接的查询结果一定是...>= 内连接的查询结果。...,比如:两条select语句的结果拼接在一起。
领取专属 10元无门槛券
手把手带您无忧上云