最近在项目里,有个临时的小需求,需要将一些行列交叉结构的表格进行汇总合并,转换成规范的一维表数据结构进行后续的分析使用。...从一开始想到的使用VBA拼接字符串方式,完成PowerQuery的M语言查询字符串,然后转换成使用插件方式来实现相同功能更顺手,最后发现,在当前工作薄里使用PowerQuery来获取当前工作薄的其他工作表内容...,也是可行的,并且不需要转换智能表就可以把数据抽取至PowerQuery内。...再最后,发现PowerQuery直接就支持了这种多工作表合并,只要自定义函数时,定义的参数合适,直接使用自定义函数返回一个表结果,就可以展开后得到多行记录的纵向合并(类似原生PowerQuery在处理同一文件夹的多个文件纵向合并的效果...整个实现的过程,也并非一步到位,借着在知识星球里发表,经过各星友一起讨论启发,逐渐完善起来最终的结果。探索是曲折的,但众人一起合力时,就会有出乎意料的精彩结果出来。
学习Excel技术,关注微信公众号: excelperfect 这里的应用场景如下: “在工作表Sheet1中存储着数据,现在想要在该工作表的第O列至第T列中搜索指定的数据,如果发现,则将该数据所在行复制到工作表...用户在一个对话框中输入要搜索的数据值,然后自动将满足前面条件的所有行复制到工作表Sheet2中。” 首先,使用用户窗体设计输入对话框,如下图1所示。 ?...Set wks = Worksheets("Sheet1") With wks '工作表中的最后一个数据行 lngRow = .Range("A" &Rows.Count...'由用户在文本框中输入 FindWhat = "*" &Me.txtSearch.Text & "*" '调用FindAll函数查找数据值 '存储满足条件的所有单元格...Sheets("Sheet2").Cells.Clear '获取数据单元格所在的行并复制到工作表Sheet2 For Each rngFoundCell
如果将数据存储在关系数据库中,最好将数据规范化,通常需要将数据拆分为通过键逻辑连接的多个表。大多数非简易的查询都需要多个表的连接来完成。本文简要介绍了SQL连接,重点介绍了内连接和外接之间的区别。...当我们比较的两个表中列的名称相同时,可以使用更短的语法: select * from t1 inner join t2 using (id); 这个结果将只有一个id列,因为我们明确表示用id匹配:...例如,考虑客户下订单,订单细节在一个单独的表中(因为客户可以有多个订单)。...最后,我们可能希望连接两边的行总是出现在结果表中。...,当union删除重复项时,完整的外部连接不删除;因此,在某些特殊情况下,结果可能会有所不同。
含义: 又称为多表查询,当查询的字段来自于多个表时,就会用到连接查询 分类: 按年代分类: sql92标准(仅支持内连接) sql99标准(除了全外连接外都支持)【推荐】按功能分类: 内连接(包括等值连接...,非等值连接,子连接) 外连接(包括左外连接,右外连接,全外连接) 交叉连接 # DQL函数语句--连接查询 /* 含义:又称为多表查询,当查询的字段来自于多个表时,就会用到连接查询 分类: 按年代分类...`department_id`; # 外连接 /* 用于查询一个表中有,另一个表中没有的记录 特点: 外连接的查询结果为主表中的所有记录 如果表中有和它匹配,则显示匹配的值 如果没有匹配值...* FROM employees LIMIT 10,15; 联合查询 union查询: 将多条查询语句的结果合并成一个结果 应用场景: 要查询结果来自多个表,且多个表没有直接的连接关系,单查询的信息一致...应用场景:要查询结果来自多个表,且多个表没有直接的连接关系,单查询的信息一致 特点: 要求多条查询语句的查询列数是一致的 要求多条查询语句每一列的类型和顺序最好是一致的 UNION关键字会自动去重,如果不想去重可以使用
存放的是地址。 聚集索引与非聚集索引 聚集索引,常见就是主键,一个表中只能拥有一个聚集索引。一个表中可以拥有多个非聚集索引。...IN能使用到索引,但是当表内存在多个单列索引时,MySQL不会自动选择in条件使用的索引,即使它是最优索引。...使用IN查询时,数据为相同类型的数据是可以正常使用索引的 但是,当IN里面嵌套子查询时索引就失效了!...,那么这里显示的是别名,如果不涉及对数据表的操作,那么这显示为null,如果显示为尖括号括起来的就表示这个是临时表,后边的N就是执行计划中的id,表示结果来自于这个查询产生。...其他数据库也叫做唯一索引扫描 eq_ref 出现在要连接过个表的查询计划中,驱动表只返回一行数据,且这行数据是第二个表的主键或者唯一索引,且必须为not null,唯一索引和主键是多列时,只有所有的列都用作比较时才会出现
PRIMARY KEY - NOT NULL 和 UNIQUE 的结合。确保某列(或两个列多个列的结合)有唯一标识,有助于更容易更快速地找到表中的一个特定的记录。...FOREIGN KEY - 保证一个表中的数据匹配另一个表中的值的参照完整性。 CHECK - 保证列中的值符合指定的条件。对于MySQL数据库,对CHECK子句进行分析,但是忽略CHECK子句。...三大范式: 第一范式(1NF): 第一范式是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值,或不能有重复的属性。...使用UNION和UNION ALL时,前后查询的结果集中,字段需要一致。 union 该操作符用于取得两个结果集的并集。当使用该操作符时,会自动去掉结果集中的重复行。...当使用该操作符时,不会去掉结果集中的重复行。
【1】连接查询 连接查询的意义: 在用户查看数据的时候,需要显示的数据来自多张表....内连接查询 内连接查询是最常见的连接查询,内连接查询可以查询两张或两张以上的表 内连接:[inner] join:从左表中取出每一条记录,去右表中与所有的记录进行匹配: 匹配必须是某个条件在左表中与右表中相同最终才会保留结果...,就可以通过该字段来连接查询这两个表,当该字段的值相同时就可以查出该记录。...子查询通常会使复杂的查询变得简单,但是相关的子查询要对基础表的每一条数据都进行子查询的动作,所以当表单中数据过大时,一定要慎重选择 带in关键字的子查询 使用in关键字可以将原表中特定列的值与子查询返回的结果集中的值进行比较...any关键字的子查询 any关键字表示满足其中的任意一个条件,使用any关键字时,只要满足内层查询语句结果的的任意一个,就可以通过该条件来执行外层查询语句。
本节我们用一个简单的公司管理系统,有三张表EMP,DEPT,SALGRADE来演示如何进行多表查询 示例: 显示雇员名、雇员工资以及所在部门的名字 因为上面的数据来自EMP和DEPT表,因此要联合查询...,单行数据;多行子查询是指返回单列多行数据,都是针对单列而言的,而多列子查询则是指查询返回多个列数据的子查询语句 示例:查询和SMITH的部门和岗位完全相同的所有雇员,不含SMITH本人 3、在from...(部门名,编号,地址)和人员数量 五、合并查询 在实际应用中,为了合并多个select的执行结果,可以使用集合操作符 union,union all 1、union 该操作符用于取得两个结果集的并集...当使用该操作符时,会自动去掉结果集中的重复行 示例:将工资大于2500或职位是MANAGER的人找出来 2、union all 该操作符用于取得两个结果集的并集。...当使用该操作符时,不会去掉结果集中的重复行 示例:将工资大于25000或职位是MANAGER的人找出来
SQL JOIN JOIN子句用于基于它们之间的相关列合并来自两个或更多表的行。...) JOIN:返回右表中的所有记录以及左表中匹配的记录 FULL (OUTER) JOIN:在左表或右表中有匹配时返回所有记录 这些JOIN类型可以根据您的需求选择,以确保检索到所需的数据。...这意味着如果您有一个没有CategoryID的产品,或者CategoryID在Categories表中不存在的记录,该记录将不会在结果中返回。...JOIN或INNER JOIN JOIN和INNER JOIN将返回相同的结果。 INNER是JOIN的默认连接类型,因此当您写JOIN时,解析器实际上会写INNER JOIN。...我们可以使用LEFT JOIN将两个表连接在一起,以便即使某些客户没有订单,它们仍然会在结果中显示。
,关系 一个实体转换为数据库中的一个表 关系描述两个实体之间的对应规则,包括 一对一 一对多 多对多 关系转换为数据库表中的一个列 *在关系型数据库中一行就是一个对象 三范式 经过研究和对使用中问题的总结...在数据库上右击,选择“删除数据库”可以完成删除操作 表操作 当数据库显示为高亮时,表示当前操作此数据库,可以在数据中创建表 一个实体对应一张表,用于存储特定结构的数据 点击“新建表”,弹出窗口,按提示填写信息...from关键字后面写表名,表示数据来源于是这张表 select后面写表中的列名,如果是*表示在结果中显示表中所有列 在select后面的列名部分,可以使用as为列起别名,这个别名出现在结果集中 如果要查询多个列...---- 2.3分组 按照字段分组,表示此字段相同的数据会被放到一个组中 分组后,只能查询出相同的数据列,对于有差异的数据列无法出现在结果集中 可以对分组后的数据进行统计,做聚合运算 语法: ?...结论:当需要对有关系的多张表进行查询时,需要使用连接join 连接查询 连接查询分类如下: 表A inner join 表B:表A与表B匹配的行会出现在结果中 表A left join 表B:表A与表B
order by子句对查询结果安装一个或多个属性列(多个属性逗号隔开)的升序(ASC)或降序(DESC)排列,默认为升序。...也就是 select 后面的所有列中,没有使用聚合函数的列,必须出现在 group by 后面。...limit {[offset,]row_count | row_count OFFSET offset} 7 ## 查询 1.2 连接查询 根据两个表或多个表的列之间的关系来查询数据,...1.2.1 简单连接 连接查询实际是通过表与表之间相互关联的列进行数据的查询,对于关系数据库来说,连接是查询最主要的特征。...简单连接使用逗号将两个或多个表进行连接,也是最常用的多表查询形式。
id,表示结果来自于这个查询产生; (4)如果是尖括号括起来的 ,与类似,也是一个临时表,表示这个结果来自于union查询的id为M,N的结果集。...(3)eq_ref:主键或者唯一索引中的所有字段被用于连接使用,只会返回一行匹配的数据。简单的select查询语句不会出现这种情况。 (4)ref:普通索引扫描,可能返回多个符合查询条件的行。...6、key: 实际使用哪个索引来优化对该表的访问;select_type为index_merge时,这里可能出现两个以上的索引,其他的select_type这里只会出现一个。...,一种是使用索引,另一种是filesort(基于快排实现的外部排序,性能比较差),当数据量很大时,这将是一个CPU密集型的过程,所以可以通过建立合适的索引来优化排序的性能 using join buffer...第四:(id = 1):【select d1.name, … d2 from … d1】:select_type为PRIMARY表示该查询为最外层查询,table列被标记为 “derived3”表示查询结果来自于一个衍生表
具体来说,UNION 和 UNION ALL 用于计算两个集合的并集,返回出现在第一个查询结果或者第二个查询结果中的数据。...下面是 UNION 操作的示意图: INTERSECT 操作符用于返回两个集合中的共同部分,即同时出现在第一个查询结果和第二个查询结果中的数据,并且排除了结果中的重复数据。...INTERSECT 运算的示意图如下: EXCEPT 或者 MINUS 操作符用于返回两个集合的差集,即出现在第一个查询结果中,但不在第二个查询结果中的记录,并且排除了结果中的重复数据。...06 JOIN 在 SQL 中,不仅实体对象存储在关系表中,对象之间的联系也存储在关系表中。因此,当我们想要获取这些相关的数据时,需要使用到另一个操作:连接查询(JOIN)。...集合操作将两个集合合并成一个更大或更小的集合;连接查询将两个集合转换成一个更大或更小的集合,同时获得了一个更大的元素(更多的列)。
具体来说,UNION 和 UNION ALL 用于计算两个集合的并集,返回出现在第一个查询结果或者第二个查询结果中的数据。...INTERSECT 操作符用于返回两个集合中的共同部分,即同时出现在第一个查询结果和第二个查询结果中的数据,并且排除了结果中的重复数据。INTERSECT 运算的示意图如下: ?...EXCEPT 或者 MINUS 操作符用于返回两个集合的差集,即出现在第一个查询结果中,但不在第二个查询结果中的记录,并且排除了结果中的重复数据。EXCEPT 运算符的示意图如下: ?...JOIN 在 SQL 中,不仅实体对象存储在关系表中,对象之间的联系也存储在关系表中。因此,当我们想要获取这些相关的数据时,需要使用到另一个操作:连接查询(JOIN)。...集合操作将两个集合合并成一个更大或更小的集合;连接查询将两个集合转换成一个更大或更小的集合,同时获得了一个更大的元素(更多的列)。
外连接 其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。...左外连接 也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以NULL 来填充。...右外连接,也称右连接,右表为主表,右表中的所有记录都会出现在结果集中。左连接和右连接可以互换,MySQL 目前还不支持全外连接。...要同时修改数据库中两个不同表时,如果它们不是一个事务的话,当第一个表修改完,可能第二个表修改过程中出现了异常而没能修改,此时就只有第二个表依旧是未修改之前的状态,而第一个表已经被修改完毕。...数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性。
外连接 其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。...左外连接,也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以NULL 来填充。...右外连接,也称右连接,右表为主表,右表中的所有记录都会出现在结果集中。左连接和右连接可以互换,MySQL 目前还不支持全外连接。...要同时修改数据库中两个不同表时,如果它们不是一个事务的话,当第一个表修改完,可能第二个表修改过程中出现了异常而没能修改,此时就只有第二个表依旧是未修改之前的状态,而第一个表已经被修改完毕。...数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性。
联合查询 基本概念: 可合并多个相似的选择查询结果的结果集,等同于将一个表追加到另一个表,从而实现将两个表的查询结果组合到一起,使用 Union 或 Union all。...外连接(Outer Join) 一张表作为主表(表中记录都会保留),根据条件去匹配另一张从表中的记录,从而得到目标数据。...Using 关键字 是在连接查询中替代 on 关键字的。 使用前提是两张表连接的字段是同名的,并且最终在结果只保留一个字段。...(class_id); 子查询 当一个查询是另一个查询的条件时,称之为子查询(Sub Query)。...分类 按功能来分: 标量子查询: 子查询返回结果是一个数据 列子查询: 返回结果是一列 行子查询: 返回结果时一行 表子查询: 返回结果是多行多列 Exists 子查询: 返回结果是 1 或 0 按位置来分
外连接 其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。...左外连接 也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以NULL来填充。...右外连接 也称右连接,右表为主表,右表中的所有记录都会出现在结果集中。左连接和右连接可以互换,MySQL目前还不支持全外连接。...要同时修改数据库中两个不同表时,如果它们不是一个事务的话,当第一个表修改完,可能第二个表修改过程中出现了异常而没能修改,此时就只有第二个表依旧是未修改之前的状态,而第一个表已经被修改完毕。...数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性。
它经常出现在3个位置上,分别是SELECT后面、FROM/JOIN后面,还有WHERE/HAVING后面。 当子查询出现在SELECT后面时,其作用通常是要为结果添加一列。...子查询出现在FROM/JOIN后面,是我们最常用的方式,就是将子查询的结果作为中间表,继续基于这个表做分析。 当子查询出现在WHERE/HAVING后面时,则表示要使用子查询返回的结果做过滤。...这里根据子查询返回的结果数量,分三种情况,即1行1列、N行1列、N行N列。 当返回结果为1行1列时,实际上就是返回了一个具体值,这种子查询又叫标量子查询。...标量子查询的结果,可以直接用比较运算符来进行计算。 当返回结果是N行1列时,实际上就是返回了一个相同类型数值的集合。因此可以使用IN谓词判断,同时也可以配合ANY、SOME、ALL等关键字使用。...当返回结果是N行N列时,实际上就是返回一个临时表,这时就不能进行值的比较了,而是使用EXISTS谓词判断返回的集合是否为空。
领取专属 10元无门槛券
手把手带您无忧上云