标签:Excel技巧 有时候,我们使用Excel建立了大的数据库,但其中的某些列是隐藏的。现在,想将所有列(未隐藏列和隐藏列)的宽度进行更改,例如改为5。...然而,如果选择工作表中的所有列,然后使用功能区“开始”选项卡“单元格”组中的“格式——列宽”命令来修改列宽,此时隐藏的列将会被取消隐藏。...解决上述问题的一个方法是:使用功能区“开始”选项卡“单元格”组中的“格式——默认列宽”命令,如下图1所示。 图1 单击“默认列宽”命令后,会弹出一个名为“标准列宽”的对话框,如下图2所示。 图2
excelperfect Q:数据放置在列A中,我要得到这些数据中任意3个数据的所有可能组合。如下图1所示,列A中存放了5个数据,要得到这5个数据中任意3个数据的所有可能组合,如列B中所示。...图1 (注:这是无意在ozgrid.com中看到的一个问题,我觉得程序编写得很巧妙,使用了递归的方法来解决,非常简洁,特将该解答稍作整理后辑录于此与大家分享!)...Dim n AsLong Dim vElements As Variant Dim lRow As Long Dim vResult As Variant '要组合的数据在当前工作表的列...Then lRow = lRow + 1 Range("B" & lRow) = Join(vResult, ", ") '每组组合放置在多列中...代码的图片版如下: ? 如果将代码中注释掉的代码恢复,也就是将组合结果放置在多列中,运行后的结果如下图2所示。 ? 图2
5.mysql 优化器 ---- mysql 优化器会做一些特殊优化,比如对于索引查找max(索引列)可以直接进行定位。 遇到max,min 是可以在列上做索引。...3.索引尽量是高选择性的 而且要留意基数值,基数值指的是一个列中不同值的个数,显然, 最大基数意味着该列中的每个值都是唯一的,最小基数意味着该列中的所有值都是相同的,索引列的基数相对于表的行数较高时,...4.使用更短的索引 可以考虑前缀索引,但应确保选择的前缀的长度可以保证大部分值是唯一的。 如:alter table test add key(col(6)) 衡量不同前缀索引唯一值比例。...6.如果是唯一值得列,创建唯一索引会更佳,也可以确保不会出现重复数据. 7.使用覆盖索引能大大提高性能 覆盖索引:所有数据都可以从索引中得到,而不需要去读物理记录。...例如某个复合索引idx_a_b_c 建立在表tb1 的 a、b、c 列上, 那么对于如下的sql 语句 select a,b from tb1 where a = ? and b = ?
聚合使用以下三种方法之一执行,优先顺序如下: 当聚合按表的分布列分组时,Citus 可以将整个查询的执行下推到每个 worker。在这种情况下支持所有聚合,并在 worker 上并行执行。...在这一步之后,count(distinct) 聚合会自动切换到使用 HLL,而无需对您的查询进行任何更改。您应该能够在表的任何列上运行近似 count distinct 查询。...但是,在某些情况下,带有 LIMIT 子句的 SELECT 查询可能需要从每个分片中获取所有行以生成准确的结果。例如,如果查询需要按聚合列排序,则需要所有分片中该列的结果来确定最终聚合值。...它评估几个可能的 join 顺序并创建一个 join 计划,该计划需要通过网络传输最少的数据。 共置连接 当两个表共置时,它们可以在它们的公共分布列上有效地 join。...重新分区连接 在某些情况下,您可能需要在除分布列之外的列上连接两个表。对于这种情况,Citus 还允许通过动态重新分区查询的表来连接非分布 key 列。
本文实例讲述了PHP实现给定一列字符,生成指定长度的所有可能组合。...分享给大家供大家参考,具体如下: 给定一列字符,生成指定长度的所有可能的组合: 如:a,b,c,d,e 或 0-9 生成长度 1:a, b, c, d, e; 长度2 :aa, ab, ac, ad...n"; } } } 用phpcmd小助手( )运行代码/ / 以上为长度为1 长度为2的。 希望本文所述对大家PHP程序设计有所帮助。
♣ 题目部分 在Oracle中,如何列举某个用户下所有表的注释及列的注释?...♣ 答案部分 可以使用DBA_TAB_COMMENTS视图来查询表的注释,使用DBA_COL_COMMENTS视图来查询列的注释。...它们的示例分别如下所示: 某个用户下所有表的注释: SELECT D.OWNER, D.TABLE_NAME, D.COMMENTS FROM DBA_TAB_COMMENTS D WHERE D.OWNER...某个用户下某个表的所有列的注释: SELECT D.OWNER, D.TABLE_NAME,D.COLUMN_NAME, D.COMMENTS FROM DBA_COL_COMMENTS D WHERE...& 说明: 有关Oracle数据字典的更多内容可以参考我的BLOG:http://blog.itpub.net/26736162/viewspace-2153324/ 本文选自《Oracle程序员面试笔试宝典
索引从物理上可以分为:聚集索引,非聚集索引 从逻辑上可以分为:普通索引,唯一索引,主键索引,联合索引,全文索引 索引优化策略 不要在索引列上进行运算或使用函数 在列上进行运算或使用函数会使索引失效,从而进行全表扫描...这时候索引的作用只是用于优化WHERE条件的查找 如果在a b列上建立联合索引,该如何建立,才能使查询效率最高 select count(distinct a) / count(*), count(distinct...b) / count(*), count(*) from table 执行如下语句,假设3个输出依次为0.001,0.373,16049,可以看到b列的选择性最高,因此将其作为联合索引的第一列,即建立...一般区分度在80%以上的时候就可以建立索引,区分度可以使用 count(distinct(列名))/count(*) 来计算 明确知道只会返回一条记录,可以加limit1 当查询确定只有一条记录时,...因此我们选择足够长的前缀保证较高的区分度,同时又不能太长(以便节约空间) 可以进行如下实验 select count(distinct left(email, 5)) / count(*) as col5
索引从物理上可以分为:聚集索引,非聚集索引 从逻辑上可以分为:普通索引,唯一索引,主键索引,联合索引,全文索引 索引优化策略 不要在索引列上进行运算或使用函数 在列上进行运算或使用函数会使索引失效,从而进行全表扫描...这时候索引的作用只是用于优化WHERE条件的查找 如果在a b列上建立联合索引,该如何建立,才能使查询效率最高 select count(distinct a) / count(*), count(distinct...b) / count(*), count(*) from table 执行如下语句,假设3个输出依次为0.001,0.373,16049,可以看到b列的选择性最高,因此将其作为联合索引的第一列,即建立...一般区分度在80%以上的时候就可以建立索引,区分度可以使用 count(distinct(列名))/count(*) 来计算 明确知道只会返回一条记录,可以加limit1 当查询确定只有一条记录时,可以加...因此我们选择足够长的前缀保证较高的区分度,同时又不能太长(以便节约空间) 可以进行如下实验 select count(distinct left(email, 5)) / count(*) as col5
引言:本文整理自vbaexpress.com论坛,有兴趣的朋友可以研阅。...Q:我在列D的单元格中存放着一些数据,每个单元格中的多个数据使用换行分开,列E是对列D中数据的相应描述,我需要在列E的单元格中查找是否存在列D中的数据,并将找到的数据标上颜色,如下图1所示。 ?...A:实现上图1中所示效果的VBA代码如下: Sub ColorText() Dim ws As Worksheet Dim rDiseases As Range Dim rCell...End If Loop Next iDisease Next rCell End Sub 代码中使用Split函数以回车符来拆分单元格中的数据并存放到数组中...,然后遍历该数组,在列E对应的单元格中使用InStr函数来查找是否出现了该数组中的值,如果出现则对该值添加颜色。
同样在联结多个表时使用索引也可以提高效率. 2) 另一个使用索引的好处是,它提供了主键(primary key)的唯一性验证.。那些LONG或LONG RAW数据类型, 你可以索引几乎所有的列....使用索引需要注意的地方: 1、避免在索引列上使用NOT , 我们要避免在索引列上使用NOT, NOT会产生在和在索引列上使用函数相同的影响....当ORACLE”遇到”NOT,他就会停止使用索引转而执行全表扫描. 2、避免在索引列上使用计算. WHERE子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描....如果至少有一个列不为空,则记录存在于索引中.举例: 如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,...除了使用索引,我们还有其他能减少资源消耗的方法: 1、用EXISTS替换DISTINCT: 当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT.
12.1.2COUNT()函数: COUNT()有两种用法: COUNT(*)对表中所有行的数目进行计数。 COUNT(column)对某一列的行的数目进行计数。...)如果指定某一列,如果列上有null,则会忽略该行;但是COUNT(*)不会。...MAX():求某一列上的最大值(最大数值或日期,对于文本数据返回最后一行,会自动忽略null值行)。...MIN():求某一列上的最小值(最小值与最小日期,对于文本数据返回第一行,会自动忽略null值行)。 SUM():求某一列上的所有值之和(会自动忽略null值行)。...12.2聚集不同值: 以上5个函数都可以如下使用: 对所有的行执行计算,指定ALL参数(默认指定,也就是说不需要指定) 对包含不同的值,指定DISTINCT参数 查找所有不同价格的价格平均值 SELECT
DISTINCT 关键字 DISTINCT 是 MySQL 中用于从查询结果中去除重复记录的关键字。当需要获取唯一值或组合时,可以在 SELECT 语句中使用DISTINCT。...DISTINCT 关键字消除了重复的城市名,使得每个城市只出现一次。数据库在处理时只保留不同的值。...COUNT(DISTINCT name) 确保只计算不同的用户名称,避免同一用户在同一城市多次计入。每个城市的用户数量为2,说明每个城市都只有两个不同的用户。...作用于所有列: DISTINCT关键字作用于查询结果的所有列。如果你只想要某一列的唯一值,但仍然在SELECT语句中列出了其他列,那么这些列的值也会被考虑在内,以确定行的唯一性。...因此,如果表中有多行包含NULL值,并且这些行在其他列上的值也相同,那么这些NULL值将被视为重复,并且只会在结果集中出现一次。
下面我就自己的工作经验,分享一下如何写出更快的 SQL 一、查看执行计划来选择更快的 SQL 在写 SQL 的初期,你可能不知道到底是使用 UNION ALL 好还是 FULL JOIN 好,是使用 EXISTS...NOT 我们要避免在索引列上使用 NOT , NOT 会产生在和在索引列上使用函数相同的影响,会导致使用索引转而执行全表扫描。...避免在索引列上使用计算 WHERE 子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描....总是使用索引的第一个列 如果索引是建立在多个列上, 只有在它的第一个列(leading column)被 where 子句引用时,优化器才会选择使用该索引。...ORDER BY 中所有的列必须包含在相同的索引中并保持在索引中的排列顺序。 ORDER BY 中所有的列必须定义为非空。
正是基于这样一个特性,对于NULL值列上的B 树索引导致了is null/is not null不走索引的情形,下面描述了NULL值与索引以及索引NULL列上的执行计划,如何使得NULL值走索引的情形。...--------------------------------------------- 2 - filter("ID" IS NOT NULL) -->从上面的测试可知,尽管当前表上id列上的所有值都为...-->此时Oracle 选择了单列唯一索引I_T1_ID -->看到此,不知道大家是否已明白,即哪个列为is not null,则会使用该列上的索引,原因还是那句话,索引不存储null值。...null值存在,但由于列id上具有not null 约束,且id列与val列存在复合唯一索引,因此此时选择了索引快速全扫描 -->其余不同组合情形大致相同,不再演示 -->为表t1新增一条val为null...故在基于单列创建B树唯一索引或多列创建B树复合唯一索引的情形下, 当列上允许为null值时 where子句使用了基于is null的情形,其执行计划走全表扫描。
2、使用表的别名: 当在SQL语句中连接多个表时, 尽量使用表的别名并把别名前缀于每个列上。这样一来, 就可以减少解析的时间并减少那些由列歧义引起的语法错误。...另一个使用索引的好处是,它提供了主键(primary key)的唯一性验证。那些LONG或LONG RAW 数据类型, 你可以索引几乎所有的列。通常在大型表中使用索引特别有效。...23、避免在索引列上使用计算: WHERE子句中,如果索引列是函数的一部分,优化器将不使用索引而使用全表扫描。...如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null), ORACLE将不接受下一条具有相同A,B值(123,null)的记录(插入)。...: 如果索引是建立在多个列上,只有在它的第一个列(leading column)被where子句引用时, 优化器才会选择使用该索引。
另一个使用索引的好处是,它提供了主键(primary key)的唯一性验证.。那些 LONG 或 LONG RAW数据类型, 你可以索引几乎所有的列....如果至少有一个列不为空,则记录存在于索引中.举例:如果唯一性索引建立在表的A 列和B 列上,并且表中存在一条记录的A,B 值为(123,null) , ORACLE将不接受下一条具有相同 A,B 值(123...: 如果索引是建立在多个列上,只有在它的第一个列(leadingcolumn)被where子句引用时,优化器才会选择使用该索引.这也是一条简单而重要的规则,当仅引用索引的第二个列时,优化器使用了全表扫描而忽略了索引...ORDER BY中所有的列必须包含在相同的索引中并保持在索引中的排列顺序. ORDER BY中所有的列必须定义为非空....,类型转换没有发生在索引列上,索引的用途没有被改变.现在,假设EMP_TYPE 是一个字符类型的索引列.
所以数据段的分析对于CBO来讲非常的重要。 在本篇博文中我们重新梳理一下,从头开始,再一次走进CBO的世界。...DBMS_STATS 包对段表的分析有三个层次: 表自身的分析: 包括表中的行数,数据块数,行长等信息。 列的分析:包括列值的重复数,列上的空值,数据在列上的分布情况。...索引的分析: 包括索引叶块的数量,索引的深度,索引的聚合因子等。 我们现在说的直方图,单指第二项的最后一种 列分析中 数据在列上的分布情况。...当 Oracle 做直方图分析时,会将要分析的列上的数据分成很多数量相同的部分,每一部分称为一个 bucket,这样 CBO 就可以非常容易地知道这个列上的数的分布情况,这种数据的分布将作为一个非常重要的因素纳入到执行计划成本的计算当中...默认情况下,dbms_stats包会对所有的列做直方图分析。
另一个使用索引的好处是,它提供了主键(primary key)的唯一性验证.。那些LONG或LONG RAW数据类型, 你可以索引几乎所有的列. 通常, 在大型表中使用索引特别有效....回到顶部 (22) 避免在索引列上使用计算 WHERE子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描....如果至少有一个列不为空,则记录存在于索引中.举例: 如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,...如果索引是建立在多个列上, 只有在它的第一个列(leading column)被where子句引用时,优化器才会选择使用该索引....ORDER BY中所有的列必须包含在相同的索引中并保持在索引中的排列顺序. ORDER BY中所有的列必须定义为非空. WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列.
另一个使用索引的好处是,它提供了主键(primary key)的唯一性验证.。那些LONG或LONG RAW数据类型, 你可以索引几乎所有的列. 通常, 在大型表中使用索引特别有效....(21) 避免在索引列上使用NOT 通常, 我们要避免在索引列上使用NOT, NOT会产生在和在索引列上使用函数相同的影响....如果至少有一个列不为空,则记录存在于索引中.举例: 如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,...: 如果索引是建立在多个列上, 只有在它的第一个列(leading column)被where子句引用时,seo/' target='_blank'>优化器才会选择使用该索引....ORDER BY中所有的列必须包含在相同的索引中并保持在索引中的排列顺序. ORDER BY中所有的列必须定义为非空. WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列.
另一个使用索引的好处是,它提供了主键(primary key)的唯一 性验证.。那些 long或long raw数据类型, 你可以索引几乎所有的列. 通常, 在大 型表中使用索引特别有效....当 oracle”遇到”not,他就会停止使用索引转而执行全表扫描. 22.避免在索引列上使用计算: where子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描....如果至少有一个列不为空,则记录存在于索引中.举例: 如 果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的 A,B 值为 (123,null) , oracle将不接受下一条具有相同 A,B...: 如果索引是建立在多个列上, 只有在它的第一个列(leading column)被 where 子句引 用时,优化器才会选择使用该索引....order by 中所有的列必须包含在相同的索引中并保持在索引中的排列顺序. order by中所有的列必须定义为非空.
领取专属 10元无门槛券
手把手带您无忧上云