在日常运维中,经常需要监控某个进程,并打印某个进程的监控结果,通常需要打印匹配某个结果的行以及其前后各N行。...2)打印/opt/test中所有匹配"main is failed"的行及其前1行 [root@mq-master02 ~]# cat /opt/test |grep "main is failed"...3)打印/opt/test中所有匹配"main is failed"的行及其后1行 [root@mq-master02 ~]# cat /opt/test |grep "main is failed"...192.168.10.17 4)打印/opt/test中所有匹配"main is failed"的行及其前后各1行 [root@mq-master02 ~]# cat /opt/test |grep...192.168.10.17 5)把/opt/test中所有匹配"main is failed"的行及其前1行的结果打印到/root/result.log中,并加上时间 [root@mq-master02
该函数接受单元格对象、代表该对象属性的字符串和属性值作为参数,返回满足属性值的所有单元格。...图1 下面使用FindCells函数查找并选择所有红色背景色的单元格,代码如下: Sub UseFindCellsExample() FindCells(ActiveSheet.UsedRange...3.参数calltype,必需,一个vbCallType型的常量,代表被调用的过程的类型,可以是vbGet(返回属性)、vbLet(修改属性)、vbMethod(执行方法)、vbSet(设置对象)。...", VbGet) End Sub 返回值6,是代表黄色的颜色值。...) EndSub 会返回错误,因为参数procname仅接受单个的条目,这就需要使用我们在前面的自定义函数FindCells,将其拆分成单个的元素。
SELECT a.id as lang_id, a.name as name, b.cnt as cnt FROM programming_lang a...
column from table; 该SQL语句的检索结果将返回表中的所有行,数据没有过滤(过滤将得出结果集的一个子集),也没有排序(如没有明确排序查询结果,则返回数据的顺序没有特殊意义,只要返回相同数目的行...= N; where子句中,对过滤的值,有的用单引号,有的不用,原因在于:单引号用于限定字符串,如果将值与串类型的列进行比较,则需要,如用来与数值列比较,则不用引号 3、范围值检查 select column...column <=Y; and,用在where子句中的关键字,用来指示检索满足所有给定条件的行;即:and指示DBMS只返回满足所有给定条件的行(可添加多个过滤条件,每添加一条就要使用一个and) 2、...column=X和Y的column2的行(in操作符用来指定匹配值的清单的关键字,功能和or相当) 圆括号在where子句中还有另一种用法,in操作符用来指定条件范围,范围中的每个条件都可以进行匹配;in...%一样,但下划线通配符只匹配单个字符而不是多个字符(与%能匹配0个字符不一样,总是匹配一个字符) 3、使用通配符的技巧 ①不要过度使用通配符(如果其他操作符能达到同样目的,应使用其他操作符) ②在确实需要使用通配符时
NULL 与不匹配 在通过过滤选择出不具有特定值的行时,你可能希望返回具有 NULL 值的行。但是,不行。因为未知具有特殊的含义,数据库不知道它们是否匹配,所以在匹配过滤或不匹配过滤时不返回它们。...事实上,目前为止所学过的所有类型的 WHERE子句都可以用 HAVING 来替代。唯一的差别是,WHERE 过滤行,而 HAVING 过滤分组。...通常,子查询将返回单个列并且与单个列匹配,但如果需要也可以使用多个列。 虽然子查询一般与IN操作符结合使用,但也可以用于测试等于(=)、不等于()等。...例如,一个特殊词的搜索将会返回包含该词的所有行,而不区分包含单个匹配的行和包含多个匹配的行(按照可能是更好的匹配来排列它们)。类似,一个特殊词的搜索将不会找出不包含该词但包含其他相关词的行。...所有这些限制以及更多的限制都可以用全文本搜索来解决。在使用全文本搜索时,MySQL不需要分别查看每个行,不需要分别分析和处理每个词。MySQL 创建指定列中各词的一个索引,搜索可以针对这些词进行。
from products where prod_price = 2.50; 从products表中检索两个列,但不返回所有行,只返 回prod_price值为2.50的行 WHERE子句操作符...MySQL在执行匹配时默认不区分大小写,所 以fuses与Fuses匹配。...%告诉MySQL接受jet之后的任意字符,不 管它有多少字符。 下划线(_)通配符 下划线的用途与%一样,但下划线只匹配单个字符而不是多个字符。...包含 文本1000的所有行 REGEXP后所跟的东西作 为正则表达式(与文字正文1000匹配的一个正则表达式)处理。...HAVING非常类似于WHERE。事实上,目前为止所 学过的所有类型的WHERE子句都可以用HAVING来替代。唯一的差别是 WHERE过滤行,而HAVING过滤分组。
SELECT prod_name, prod_price FROM Products WHERE prod_price = 3.49; 分析 这条语句从 products 表中检索两个列,但不返回所有行...,只返回 prod_price 值为 3.49 的行,输出: ?...屏幕快照 2018-05-27 08.52.12.png 不匹配检查 列出所有不是供应商 DLL01 制造的产品: SELECT vend_id, prod_name FROM Products WHERE...SQL 理解 WHERE 子句为:由供应商 BRS01 制造的价格为 10 美元以上的所有产品,以及由供应商 DLL01 制造的所有产品,而不管其价格如何。...注意 通配符%不能匹配 NULL,子句WHERE prod_name LIKE '%'不匹配产品名称为 NULL 的行。
它类似于 WHERE ,但不同的是 在聚合之前执行,而 之后进行。 可以从 生成的聚合结果中通过他们的别名来执行 子句。或者 子句可以筛选查询结果中未返回的其他聚合的结果。...限制HAVING如果不执行聚合则无法使用 7 Join 支持的联接类型 所有标准 SQL JOIN 支持类型: INNER JOIN,只返回匹配的行。...LEFT OUTER JOIN,除了匹配的行之外,还返回左表中的非匹配行。 RIGHT OUTER JOIN,除了匹配的行之外,还返回右表中的非匹配行。...FULL OUTER JOIN,除了匹配的行之外,还会返回两个表中的非匹配行。 CROSS JOIN,产生整个表的笛卡尔积, “join keys” 是 不 指定。...m 如果没有 ORDER BY 子句显式排序结果,结果的行选择可能是任意的和非确定性的 9 Limit by 10 Order by 11 Where prewhere .PREWHERE与WHERE
不匹配的行被排除。最常用。...左表的所有行,以及右表中匹配的行。...右表的所有行,以及左表中匹配的行。...用途:可以用在任何需要单个值的地方,如 SELECT 列表、WHERE 子句的比较条件、SET 子句等。...用途:主要用于 WHERE 子句中进行行级别的比较。需要使用括号将多个列括起来进行比较。
一、 简单查询 简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的表或视图、以及搜索条件等。...(三) 使用WHERE子句设置查询条件 WHERE子句设置查询条件,过滤掉不需要的数据行。...ALL选项表示将所有行合并到结果集合中。不指定该项时,被联合查询的结果集合中重复行将只保留一行。 联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语句中定义。...与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的数据行。...交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。
,并列出表中与连接条件相匹配的数据行,组合成新的记录。...左连接的结果集包括 LEFT OUTER子句中指定的左表的所有行,而不仅仅是连接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。...右连接: 右连接包含右边表的全部行(不管左边的表中是否存在与它们匹配的行),以及左边表中全部匹配的行。 右连接是左连接的反向连接。将返回右表的所有行。...3、交叉连接 交叉连接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉连接有显式的和隐式的,不带ON子句,返回的是两表的乘积,也叫笛卡尔积。...); 4、带ALL关键字的子查询 ALL关键字与ANY和SOME不同,使用ALL时需要同时满足所有内层查询的条件。
A和B,A和B表使用where子句正确联结, where子句指示MySQL匹配A表中的A_id和B表中的B_id相匹配,要匹配的两列以A.A_id和B.B_id完全限定表名(当引用的列可能存在二义性,必须使用完全限定表名...(用一个点分隔的表名和列名)) PS:where子句的重要性 在一条select语句中联结几个表时,相应的关系是在运行中构造的;在联结两个甚至多个表时,实际上是将第一个表中的每一行与第二个表中的每一行配对...,where子句作为过滤条件,它只包含匹配的给定条件的行。...没有where子句,第一个表中每个行将与第二个表中的每个行匹配,而不管逻辑上是否可以配在一起。...A, B order by A_name, B_name; PS:应保证所有联结都有where子句,否则MySQL将返回比想要的数据多得多的数据,还应保证where子句的正确性。
也就是两个表中的所有的行的所有可能的组合。这相当于内连接没有连接条件或者连接条件永远为真。 如果一个有 m 行的表和另一个有 n 行的表,它们交叉连接将返回 m * n 行数据。...左连接以左表的数据行为基础,根据连接匹配右表的每一行,如果匹配成功则将左表和右表的行组合成新的数据行返回;如果匹配不成功则将左表的行和 NULL 值组合成新的数据行返回。...2.3、DQL 子句:WHERE 默认情况下,SELECT 查询数据表中的所有行数。但我们只想查询满足一定条件的数据,就要用到 WHERE 子句。...;③ “%” 匹配零或多个任意字符;④ “_” 匹配单个任意字符;⑤ 如果需要匹配通配符,则需要使用 “\” 转义字符,如 “\%” 和 “\_”;⑥ 使用通配符匹配文本时,不区分字母大小写;⑦ 如果...,它需要一个子查询 subquery 作为参数;③ 如果子查询 subquery 返回了至少一个数据行,则 EXISTS 的计算结果为 TRUE,否则计算结果为 FALSE;④ EXISTS 运算时,一旦子查询找到一个匹配的行
如果你需要一个不包含任何重复行的结果集,并且不介意MySQL为你去除这些重复行,那么使用UNION。 如果你需要包含所有行,包括重复行,并且希望操作更快地执行,那么使用UNION ALL。...如果不指定条件,将删除表中的所有行,但表的结构和约束仍然保留。...2、JOIN JOIN 子句是在FROM子句之后,根据相关列合并两个或多个表中的行,它决定了如何匹配不同表中的行。...5、HAVING HAVING 子句与 WHERE 子句类似,根据指定的条件过滤组。但它是在分组完成后应用的。该子句可用于过滤聚合后不符合某些条件的组。...Server层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖MySQL的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程、
内连接默认会排除不匹配的数据行,因此它常用于查询两个表之间有逻辑关系的数据。 不同于笛卡尔积:尽管内连接涉及笛卡尔积的概念,但它对笛卡尔积进行了筛选(使用ON或WHERE子句来限制返回的数据)。...左外连接(LEFT JOIN) 简要回顾:左外连接将返回左表的所有记录,即使它们在右表中没有匹配的记录。对于没有匹配的右表记录,右表的字段将显示NULL。...如果某个表中没有匹配的记录,则该表的相关字段显示NULL。但是需要注意的是,MySQL 不直接支持全外连接,通常可以通过联合左外连接和右外连接来实现。...因此,一定要小心连接条件的设置。 ON与WHERE的区别 ON子句:用于指定连接条件,它是在连接过程中确定行是否匹配的条件。 WHERE子句:用于进一步筛选结果集,可以用来过滤已连接的结果集中的行。...在内连接中,ON子句和WHERE子句通常是可以互换的,但是在外连接中,ON和WHERE的作用有所不同。使用WHERE会影响外连接的结果,可能会丢失左或右表的某些记录。
如果将值和字符串类型的比较,需要使用限定符号 3、用来与数值列进行比较的值,则不用括号。...不匹配检查 SELECT vend_id, prod_name, prod_price FROM Products WHERE vend_id 'DLL01' -- 不匹配检查条件 范围值检查...20005; 笔记:SUM()函数会自动忽略值为NULL的行 聚集不同值 上面的5个聚集函数都可以如下使用: 对所有的行执行计算,指定ALL参数或不指定参数(因为ALL是默认行为) 只包含不同的值,指定...; -- 指定联结条件 如果上面的代码中没有WHERE子句来指定联结条件,则返回的是笛卡尔积,返回出来数的行就是第一个表中的行乘以第二个表中的行。...,但是有时候也需要包含那些没有关联行的行记录,比如下面的场景中: 对每个顾客下的订单数进行统计,包含那些至今尚未下单的顾客 列出所有产品以及订购数量,包含没有人订购的产品 计算平均销售规模,包含那些至今尚未下订单的顾客
你必须请求数据库管理员的帮助。 过滤语句,一般指的是where 子句。 数据库表一般包含大量的数据,很少需要检索表中所有行。通常只 会根据特定操作或报告的需要提取表数据的子集。...为此目 的,SQL的SELECT语句为客户机应用检索出超过实际所需的 数据,然后客户机代码对返回数据进行循环,以提取出需要 的行。 通常,这种实现并不令人满意。...可以看到这里显示的是is,而不是==,至于为什么可以查看我的整理1800篇sql语句中查看。 NULL与不匹配 在通过过滤选择出不具有特定值的行时,你 可能希望返回具有NULL值的行。但是,不行。...因为未知具有 特殊的含义,数据库不知道它们是否匹配,所以在匹配过滤 或不匹配过滤时不返回它们。 因此,在过滤数据时,一定要验证返回数据中确实给出了被 过滤列具有NULL的行。...在使用where的时候,我们一般要知道另外交给关键词,and or in not 这几个操作符号。 and 例子: OR操作符与AND操作符不同,它指示MySQL检索匹配任一条件的行。
FROM 表名 #掉SELECT查询返回的记录结果中重复的记录(所有返回列的值都相同),只返回一条 PS:ALL 关键字是默认的(不加DISTINCT默认ALL),返回所有的记录,与DISTINCT...与%一起使用,表示匹配 0 或任意多个字符 与_一起使用,表示匹配单个字符 如果需要显示%或者_,可以使用转义字符\,也可以用ESCAPE关键字自定义转义符,如: 6、IN范围查询 在 WHERE 子句中使用...FROM 表1 别名1,表1 别名2; 数据表与自身进行连接 6、外连接(out join)——左连接 从左表(table_1)中返回所有的记录,即便在右表(table_2)中没有匹配的行 SELECT...) 如果表中至少有一个匹配,则返回行 LEFT JOIN 无论右表是否有匹配,都会返回左表的所有行 RIGHT JOIN 无论左表是否有匹配,都会返回右表的所有行 9、full join mysql...LIMIT[m,]n 或 LIMIT n OFFSET m 限制 SELECT 返回结果的行数 m 指定第一个返回记录行的偏移量(显示的起始位置) n 指定返回记录行的最大数目(显示行数) m 不指定则偏移量为
ROLLUP,是GROUP BY子句的一种扩展,可以为每个分组返回小计记录以及为所有分组返回总计记录。...BY子句中表达式的值,从查询返回的每一行,计算它们与其它行的相对位置。...FIRST 功能描述:从DENSE_RANK返回的集合中取出排在最前面的一个值的行(可能多行,因为值可能相等),因此完整的语法需要在开始处加上一个集合函数以从中取出记录。...LAST 功能描述:从DENSE_RANK返回的集合中取出排在最后面的一个值的行(可能多行,因为值可能相等),因此完整的语法需要在开始处加上一个集合函数以从中取出记录。...不匹配换行符号; m:多行模式; x:扩展模式,忽略正则表达式中的空白字符。
描述 FOR SOME %ELEMENT谓词将字段中的列表元素与指定的谓词匹配。 SOME关键字指定字段中至少有一个元素必须满足指定的谓词子句。...(%KEY=2)匹配所有包含至少2个元素的字段值。 字段可以包含两个元素,也可以包含两个以上的元素。 %KEY值必须为正整数。 (%KEY=0)不匹配任何字段值。...它返回那些FavoriteColors列表中包含包含小写'l'和小写'e'的元素的行(contains操作符是大小写敏感的)。...下面的动态SQL示例使用%KEY根据FavoriteColors中的元素数量返回行。 第一个%Execute()设置%KEY=1,返回所有包含一个或多个FavoriteColors元素的行。...第二个%Execute()设置%KEY=2,返回所有包含两个或更多favoritecolor元素的行: ClassMethod ForSomeElement() { s q1 = "SELECT