标签:Excel公式,INDEX函数,MATCH函数 有时候,工作表行中的数据可能并不在第1个单元格,而我们可能会要获得行中第一个非空单元格中的数据,如下图1所示。...图1 可以使用INDEX函数/MATCH函数的组合来解决这个问题,如果找不到的话,再加上IFERROR函数来进行错误处理。...在单元格H4中输入公式: =IFERROR(INDEX(C4:G4,0,MATCH("*",C4:G4,0)),"空") 然后向下拖拉复制公式至数据单元格末尾。...公式中,使用通配符“*”来匹配第一个找到的文本,第二个参数C4:G4指定查找的单元格区域,第三个参数零(0)表示精确匹配。 最后,IFERROR函数在找不到单元格时,指定返回的值。...这里没有使用很复杂的公式,也没有使用数组公式,只是使用了常用的INDEX函数和MATCH函数组合来解决。公式很简单,只是要想到使用通配符(“*”)来匹配文本。
学习Excel技术,关注微信公众号: excelperfect 在《Excel公式技巧63:查找最后一行》中,我们使用LOOKUP函数的公式获取最后一个值或该值所在的行号。...如果列表中的前面有空,那么如何获取第一个非空值呢? 如下图1所示的工作表,在数据列中存在一些空单元格,且在第一个值前面就存在空单元格。 ?...图1 输入数组公式: =INDEX(B3:B12,MATCH(FALSE,ISBLANK(B3:B12),0)) 可以获取数据列中第一个非空单元格的值。...;TRUE;FALSE;FALSE;TRUE;TRUE;TRUE},0) MATCH函数在数组中查找第一个FALSE值的位置,即第一个非空单元格的位置,得到: 2 传递给INDEX函数,得到: =INDEX...图2 小结:通过使用IS类函数巧妙地构造TRUE/FALSE值组成的数组,从而求出想要获取的值所在的位置。 欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。
非空值函数LastnonBlank第2参数使用方法 LastnonBlank(,) 参数 描述 column 列名或者具有单列的表,单列表的逻辑判断 expression...表达式,用来对column进行过滤的表达式 第2参数是一个表达式,是对第一参数进行过滤的表达式。...如果我们第二参数只写一个常数,则等同于返回列表的最大值,主要差异表现在汇总合计上。 有2张表,一张是余额表,另外一张是日历表,并做关系链接。 ? ? 我们来看下3种写法,返回的不同结果。...解释:带常数的LastnonBlank度量值,不会显示汇总,因为只返回日期列里的最大值。因为LastnonBlank是根据ACISS大小来返回最后一个,也就是返回ACISS的最大值。...第1个度量,既然知道第2参数是常数,也就是返回最大值,日历筛选的时候,因为汇总的时候是没有指定值的,所以返回为空白。 第2个度量,是在日历表上进行筛选后进行返回最后日期,所以返回的也不带有汇总。
不通过软件,直接手工创建,不会报错,模拟的SQL,如下所示,一个主键id,外加两个timestamp类型的字段,都设置了默认值, create table test( id int not null...给这样的列分配一个NULL的值是允许的,并将该列设置为current timestamp。...对于插入的行,如果没有为该列指定明确的值,那么该列将被分配为'0000-00-00 00:00:00',并且不会发生警告。...根据是否启用了严格的SQL mode或包含NO_ZERO_DATE的SQL mode,默认值'0000-00-00 00:00:00'可能是不被允许的。...和ON UPDATE CURRENT_TIMESTAMP属性声明,假设这个建表语句中只有一个TIMESTAMP类型字段createtime,他的结构会改成, 按照上述规则(3),在第一个列之后的TIMESTAMP
同事说他通过某款商业数据同步软件将一个 MySQL 5.7.28 的库同步到 MySQL 5.7.20 的库时,如果表中含有 TIMESTAMP 数据类型、缺省值为 current_timestamp...不通过软件,直接手工创建,不会报错,模拟的 SQL ,如下所示,一个主键 id ,外加两个 timestamp 类型的字段,都设置了默认值: create table test( id int not...给这样的列分配一个 NULL 的值是允许的,并将该列设置为 current timestamp 。...对于插入的行,如果没有为该列指定明确的值,那么该列将被分配为 '0000-00-00 00:00:00' ,并且不会发生警告。...,建表的时候,就会报错,这个可能是软件的一个 bug ,或者存在其他的配置控制,但就不在数据库的范畴了。
预计阅读时间:3分钟 今日锦囊 怎么定义一个方法去填充分类变量的空值? 之前我们说过如何删除掉缺失的行,但是如何我们需要的是填充呢?比如说用众数来填充缺失,或者用某个特定值来填充缺失值?...这个也是我们需要掌握的特征工程的方法之一,对于用特定值填充缺失,其实比较简单了,我们可以直接用fillna() 方法就可以,下面我来讲一个通用的办法,除了用特定值填充,我们还可以自定义,比如说用”众数“...这里我们用到了TransformerMixin方法,然后自定义一个填充器来进行缺失值的填充。...这里我们造一个数据集来测试我们的代码: # 本次案例使用的数据集 import pandas as pd X = pd.DataFrame({'city':['tokyo',None,'london',...可以看出,这个数据集有三个分类变量,分别是boolean、city和ordinal_column,而这里面有两个字段存在空值。
- 在有总bps限速条件下,单个channel的bps值不能为空,也不能为非正数 三、定位原因 很明显,error信息里面也说了,DataX的配置有问题,单个channel的bps值不能为空,也不能为非正数...如果设置了总bps限速,那单个channel的bps值不能为空,也不能为非正数。 channel的数量=总bps限速/单个channel的bps值。...如果设置了总tps限速,那单个channel的tps值不能为空,也不能为非正数。 channel的数量=总tps限速/单个channel的tps值。...比如这个值设置为5,那channel的数量就是5个。...如果bps限速和tps限速只设置了一个,那以设置的那个为准,因为没设置的那个默认Integer.MAX_VALUE,肯定大于设置的那个,所以取小的数就是设置的那个。
预计阅读时间:3分钟 今日锦囊 怎么定义一个方法去填充数值变量的空值? 这个锦囊和上一个差不多了,不过这个换一个方法 Imputer 。...同样的,我们还是造一个数据集: # 本次案例使用的数据集 import pandas as pd X = pd.DataFrame({'city':['tokyo',None,'london','seattle...可以看出,这个数据集有一个数值变量quantitative_columns,存在一行缺失值,我们直接调用sklearn的preprocessing方法里的Imputer。...# 填充数值变量(基于Imputer的自定义填充器,用众数填充) from sklearn.preprocessing import Imputer class CustomQuantitativeImputer...今天的知识还有什么疑问的地方吗?欢迎留言咨询哦!
column.... from .... order by ... 1) Order by子句在整个 select语句中的位置: 始终位于最后 2) order by后可以跟什么...5)空值永远是最大的。...升序排序的时候,空值放在最后 降序排序的时候,空值放在最前面的 如果降序的时候,null在全前面,你不想要null在前面,可以加上null last eg:order by column null...where dept_id45 order by dept_id; 2》sql比较操作符 between and:在什么范围之内 in(list):在一个列表中 like:模糊查询,即值不是精确的值的时候使用...is null:对null值操作特定义的操作符,不能使用= 3》逻辑操作符 当条件有多个的时候使用 and:且逻辑 or:或逻辑 注意:and逻辑比or逻辑要高 not:非逻辑 4) 需求: 1.查找员工
给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。你可以假设除了整数 0 之外,这个整数不会以零开头。力扣66。...当数组全是9的时候,需要开辟新的数组。其他情况,不需要开辟空间。 时间复杂度:O(n)。 额外空间复杂度:O(1)。全是9的情况下是O(n)。 代码用golang编写。
(非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where次之,having最后,因为on是先把不 符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据...如果至少有一个列不为空,则记录存在于索引中.举例: 如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引....ORDER BY中所有的列必须包含在相同的索引中并保持在索引中的排列顺序. ORDER BY中所有的列必须定义为非空. WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列....任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 回到顶部 (37) 联接列 对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的。
COUNT(*) AS total_records, COUNT(DISTINCT client_id) FROM invoices; 注意: 除 COUNT() 聚合函数外,其余聚集函数只运行非空值...COUNT() 函数比较特殊,如果指定列名,则 COUNT() 函数会忽略指定列的值为空的行,但如果 COUNT() 函数中用的是通配符,则不忽略。...BY 子句可以包含任意数目的列,因而可以对分组进行嵌套,更细致地进行数据分组 如果在 GROUP BY 子句中嵌套了分组,数据将在最后指定的分组上进行汇总 GROUP BY 子句中列出的每一列都必须是检索列或有效的表达式...NULL 值的行,则 NULL 将作为一个分组返回。...如果列中有多行 NULL 值,它们将分为一组 GROUP BY 子句的位置必须在 WHERE 子句之后,ORDER BY 子句之前 SELECT date, pm.
(1)选择最有效率的表名顺序(只在基于规则的优化器中有效) ORACLE 的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将被最先处理...(非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where次之,having最后,因为on是先把不 符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据...如果至少有一个列不为空,则记录存在于索引中.举例: 如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引....任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 (37) 联接列 对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的。
每种类型都可能包含一个空值,这是一个特殊值,表示一个缺失的值,它有可能存在但不为人所知,有可能根本不存在。在特定情况下,可能希望禁止加入空值。...2.2 基本模式定义 (1)创建关系 创建一个关系,很简单。顺带一提,最后的分号是可选的。...6 空值 空值给包括算数运算、比较运算和集合运算在内的关系运算带来了特殊的问题。 比如,如果算术表达式的任一输入值为空,则该算术表达式(如+,-,*,/)结果为空。 对比较运算,这也是一个问题。...由于空值被忽略,聚集函数的输入值集合可能为空集,规定空集的count运算值为0,其它所有聚集运算会返回一个空值,在一些更加复杂的SQL结构中空值的影响会更加难以捉摸。...8.3 空关系测试 SQL中包含一个特性,测试一个子查询的结果是否存在元组,exist结构在作为参数的子查询非空时返回true值。
首先,扫描第一个表(FROM子句中最后的那个表)并对记录进行排序;然后扫描第二个表(FROM子句中最后第二个表);最后将所有从第二个表中检索出的记录与第一个表中合适记录进行合并。...如果WHERE子句包括两个可SARG和一个不可SARG的子句,那么至少可SARG的子句能使用索引(如果存在的话)帮助快速访问数据。...例如语句: SELECT * FROM customer WHERE zipcode[2,3] >"80" 在where子句中采用了非开始子串,因而这个语句也不会使用索引。...对于单列索引,如果列包含空值,索引中将不存在此记录;对于复合索引,如果每个列都为空,索引中同样不存在此记录。如果至少有一个列不为空,则记录存在于索引中。 ...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使SQLSERVER停用该索引。
推荐方案:用其它相同功能的操作运算代替,如:a is not null 改为 a>0 或a>’’等。不允许字段为空,而用一个缺省值代替空值,如申请中状态字段不允许为空,缺省为申请。...select * from gc_dfys union all select * from ls_jg_dfys (g) 联接列 对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的...(非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where次之,having最后,因为on是先把不符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引....ORDER BY中所有的列必须包含在相同的索引中并保持在索引中的排列顺序. ORDER BY中所有的列必须定义为非空. WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列.
. (1) 选择最有效率的表名顺序(只在基于规则的seo/' target='_blank'>优化器中有效): ORACLE 的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表...(非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where次之,having最后,因为on是先把不符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据...如果至少有一个列不为空,则记录存在于索引中.举例: 如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引....ORDER BY中所有的列必须包含在相同的索引中并保持在索引中的排列顺序. ORDER BY中所有的列必须定义为非空. WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列.
索引需要占物理和数据空间 索引分类: 唯一索引:唯一索引不允许两行具有相同的索引值 主键索引:为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。...主键索引要求主键中的每个值是唯一的,并且不能为空 聚集索引(Clustered):表中各行的物理顺序与键值的逻辑(索引)顺序相同,每个表只能有一个 非聚集索引(Non-clustered):非聚集索引指定表的逻辑顺序...NOT NULL: 用于控制字段的内容一定不能为空(NULL)。 UNIQUE: 控件字段内容不能重复,一个表允许有多个 Unique 约束。...①选择最有效率的表名顺序 数据库的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表将被最先处理 在FROM子句中包含多个表的情况下: 如果三个表是完全无关系的话,将记录和列名最少的表...* from emp where sal in (1500,3000,800); ①④总是使用索引的第一个列 如果索引是建立在多个列上,只有在它的第一个列被WHERE子句引用时,优化器才会选择使用该索引
主键约束相当于唯一约束+非空约束的组合,主键约束的列不允许重复,也不允许出现空值 每个表最多允许一个主键 主键约束的关键字:primary key 当创建主键的约束的时候,系统会默认在所在的列和列组合上建立对应的唯一索引...指定自增字段的初始值 alter table 表名 auto_increment=初始值; 非空约束(not null) 概念:非空约束,指字段的值不能为空,对于使用了非空约束的字段,如果用户在添加数据时没有指定值...(默认),desc是降序 order by 用于子句中可以支持单个字段,多个字段,表达式,函数,别名 order by 子句,放在查询语句的最后面,limit子句除外 --...,多个字段,表达式,函数,别名 order by 子句,放在查询语句的最后面,limit子句除外 聚合查询: 聚合函数: count( ) 统计指定列不为null的记录的行数 sum( ) 计算指定列的数值和...where where子句用来筛选from子句中指定的操作所产生的行 group by 子句用来分组where子句的输出 having子句是用来从分组的结果中进行筛选 select
3、选择最有效率的表名顺序(只在基于规则的优化器(RBO)中有效): ORACLE 的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表 (基础表也称为驱动表,driving...最好能通过WHERE子句限制记录的数目。 (非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where次之, having最后。...对于单列索引,如果列包含空值,索引中将不存在此记录。 对于复合索引,如果每个列都为空,索引中同样不存在此记录。如果至少有一个列不为 空,则记录存在于索引中。...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空 值比较将使ORACLE停用该索引。...(2)ORDER BY中所有的列必须定义为非空。 WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列。
领取专属 10元无门槛券
手把手带您无忧上云