首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【mysql】NATURAL JOIN 和 USING 连接

    章节小结 表连接的约束条件可以有三种方式:WHERE, ON, USING WHERE:适用于所有关联查询 ON:只能和JOIN一起使用,只能写关联条件。...USING:只能和JOIN一起使用,而且要求两个关联字段在关联表中名称一致,而且只能表示关联字段值相等 #关联条件 #把关联条件写在where后面 SELECT last_name,department_name...FROM employees,departments WHERE employees.department_id = departments.department_id; #把关联条件写在on后面,只能和JOIN...departments ON employees.department_id = departments.department_id; #把关联字段写在using()中,只能和JOIN一起使用 #...SQL 有两个主要的标准,分别是 SQL92 和 SQL99。92 和 99 代表了标准提出的时间,SQL92 就是 92 年提出的标准规范。

    1.2K20

    mysql join

    首先先放张图 今天聊聊mysql表join连接,其本质是拿主表每条数据取出来和子表每行数据进行循环比较,如果满足则返回,不满足返回null 首先是内连接 两者之间取交集,两边都满足返回,不满足不返回...JOIN 然后是左外连接 左外连接,此时可以理解为理解 左表为主表,右表为子表。...sp_user b ON a.seller_id = b.seller_id WHERE b.seller_id IS NULL 还有一种是全外连接 全外连接是内联结果和不满足条件的行 mysql...UNION SELECT * FROM sp_user a RIGHT OUTER JOIN tb_seller b ON FALSE 另外,阿里开发规范表示 【强制】超过三个表禁止 join...需要 join 的字段,数据类型必须绝对一致;多表关联查询 时,保证被关联的字段需要有索引。

    90510

    Mysql - join 优化

    MMR 解决的不是 join 优化,而是回表优化:   mutil-range read , 正如他的名字一样,优化的是离散范围的读,具体是优化在 主键上离散范围的读   如果是从辅助索引读取符合条件的...离散读取主键索引的情况   MMR 做的事情是 把得到的 主键先放在 read_rnd_buffer ,然后排序,然后再去主键索引读取 数据行,这样的话就能减少离散读 BKA 依赖于 MMR 进行 join...在被驱动表有主键的情况下,驱动表读一行就要去 被驱动表通过主键在B+树查找一次,如果可以一次性给许多 主键,并且是有序的话,就能大大提高效率   BKA 用上了 NLJ( index nested loop join...)情况下用不上的 join buffer,每读一行驱动表,就将连接字段放入 join buffer   然后将 join buffer 传给 MMR ,MMR 负责 去连接字段对应的被驱动表的辅助索引上读取主键...,并且放到 read_rnd_buffer ,然后排序,再去被驱动表的主键索引读取行数据 大表 join 对内存的影响:   如果被驱动表是 大表,驱动表也比较大,能被分成几个 join buffer,

    89120

    玩转mysql函授:concat以及group_concat

    二、concat_ws()函数 1、功能:和concat()一样,将多个字符串连接成一个字符串,但是可以一次性指定分隔符~(concat_ws就是concat with separator) 2、语法:...三、group_concat()函数 前言:在有group by的查询语句中,select指定的字段要么就包含在group by语句的后面,作为分组的依据,要么就包含在聚合函数中。...—— 使用group_concat() 1、功能:将group by产生的同一个分组中的值连接起来,返回一个字符串结果。...3、举例: 例7:使用group_concat()和group by显示相同名字的人的id号: ? 例8:将上面的id号从大到小排序,且用'_'作为分隔符: ?...接下来我们要查询以name分组的所有组的id和score: ?

    6K30

    Mysql - join 原理

    A left join B , B right join A on A.x = B.y   假设 A 100 行, B 1000 行 A 是驱动表,B是被驱动表 1.被驱动表上有索引的情况:(B.y...上有索引的情况)   不用额外内存   对 A 和 B 都从 硬盘中读,每读 A 一行(从主键索引上拿出 x,然后去硬盘通过 y 上索引的 B+ 树查找到对应的行),都会读 1 ~ N 行B   读...A 的一行,然后和 这 1 ~ N 行结合 放到结果集(结果集是最后返回给用户的,不算临时表)   具体只用 100 * k * log (1000) 次的磁盘读,k是不定常数 2.被驱动表上无索引的情况...  需要额外内存,被称为 join buffer   join buffer 被放入驱动表,一般选用小的当驱动表(小的度量单位指的是 表行数 * 每行大小)   对于被驱动表,从硬盘读出,并且每读出一行数据...(先放在内存),就会取这行数据 对应的条件字段(B.y) 去和内存中的小表一行行比较   把符合条件的驱动表的行 和 从磁盘中读出来的被驱动表的行 放入结果集   具体要比较 100 * 1000 次,

    96930

    mysql之join

    前言: 了不起学弟:学长啊,我最近在学习mysql,对于这个join,我也有了自己的一些看法,这个join就差不多就是把两张表连接在一起对吧!...select * from A inner join B on A.productId=B.productId(建议大家保持一个良好的编写sql习惯,不要一长条全写在一行上,这对阅读代码的来说,非常的头疼...说完inner join,我们再讲一下 left join吧。left join 和inner join 其实是很相似的。inner join 就是取两张表的交集。...而left join,就是包含了相交的地方,和左表的地方,按照刚刚的例子也就是说,包含了所有的圈A。 举个刚才的例子,假设刚刚的订单表和产品表。...如果我们left join,那我们得到的结果就是订单表的所有的记录,如果你是select * ,那条不在产品表记录的数据,后边B标的数据就是为空。

    36410

    Mysql案例之GROUP_CONCAT函数详解

    今天这篇文章记录一个最近开发中遇到的mysql实战场景,觉得还挺典型的,就在此做一下记录。...先看一下举例场景: mysql中学生表与学科表通过关联表建立关联,学生和学科为多对多的关系,现要求查询学生的数据,并根据学生表引用的多个学科中名称排列在前的学科的名称进行排序, 数据库表结构如下: CREATE...首先我们来看一下GROUP_CONCAT 函数的含义: GROUP_CONCAT函数 在 MySQL 中,GROUP_CONCAT 函数用于将查询结果按指定顺序连接成一个字符串。...r ON s.id = r.student_id LEFT JOIN course c ON c.id = r.course_id GROUP BY s.id ORDER BY GROUP_CONCAT...JOIN course c ON c.id = r.course_id WHERE s.name LIKE '%四%' GROUP BY s.id ORDER BY GROUP_CONCAT(c.name

    21.5K00

    MySQL GROUP_CONCAT 对应 ORACLE LISTAGG用法

    最近,遇到了SQL查询适配不同数据库类型的情况,看了前人写的MySQL查询代码,再想想要怎么写Oracle的,一开始愣住了。。。 现在的需求是,看看食物分类及下属的食物数据。...我们先来看看前人写的MySQL代码: SELECT fc.*, GROUP_CONCAT( f....尽管标准允许了,但是MySQL也是默认不支持这种写法的。我们需要修改sql_mode配置才能支持这种写法。 如何修改sql_mode配置?...ORACLE中可没有GROUP_CONCAT函数来帮助我们将join再group by后的多行数据合并成一行。 那Oracle有没有别的类似功能的函数呢?...如果仅仅将上面MySQL写法中的GROUP_CONCAT替换成Oracle LISTAGG的写法,Oracle表示不认识你 哼!!!

    81500
    领券