连续出现3次的值
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:申请域名、网络空间、营销软件、网站建设、巴东网站维护、网站推广。
有时候SQL版本不够高
方法:用 DISTINCT 和 WHERE 语句
算法
连续出现的意味着相同数字的 Id 是连着的,由于这题问的是至少连续出现 3 次,我们使用 Logs 并检查是否有 3 个连续的相同数字。
Id Num Id Num Id Num
1 1 2 1 3 1
注意:前两列来自 l1 ,接下来两列来自 l2 ,最后两列来自 l3 。
然后我们从上表中选择任意的 Num 获得想要的答案。同时我们需要添加关键字 DISTINCT ,因为如果一个数字连续出现超过 3 次,会返回重复元素。
MySQL
假设右边5,8那列是B列
你在要统计个数的单元格那里输入公式=COUNTIF(A:A,"10")
就可以了
哦对了,这个是excel
下面SQL代码假设表名为T,运行时请将表名T更改为实际表名,其它地方请不要动。这段代码已经实测通过。上机试试吧! SELECT T.* FROM T INNER JOIN (SELECT NAME FROM (SELECT NAME,COUNT(*) AS QTY FROM T GROUP BY NAME)A WHERE A.QTY1)B ON T.NAME=B.NAME ORDER BY T.NAME,T.ID 说明:这段代码看上去虽然比较复杂,尽管有其它比较简单的写法,但是我觉得这个写法在表数据量较大时效率会更高一些。 再给一个稍微简单的写法,其效率也差不多。 SELECT T.* FROM T, (SELECT NAME FROM T GROUP BY NAME HAVING COUNT(*)1)A WHERE T.NAME=A.NAME ORDER BY T.NAME, T.ID; 你的问题“查询一张表中 字段A 相同的记录数大于1条的记录” -- 我认为有一点笔误,因为在你提供的表中没有叫做“A”的字段,所以我上面的答案是基于问题“查询一张表中 字段NAME 相同的记录数大于1条的记录”而做出的。 如果你问题的实际要求是“查询一张表中 字段NAME 等于A,且其记录数大于1条的记录”那么只要对我上面的SQL语句加一个“Where”操作符就可以解决。以第二个SQL语句为例,这样写: SELECT T.* FROM T, (SELECT NAME FROM T WHER NAME='A' GROUP BY NAME HAVING COUNT(*)1)A WHERE T.NAME=A.NAME ORDER BY T.NAME, T.ID 尊敬的“冰风舞雨”先生如果你觉得我的回答无聊,请投诉并删除本人的作答。作为一个认真的答题者,总是希望提问者能给一个回复,不管评价是好还是坏。 ~
这个mysql是做不到的,除非你在删除的时候,对id=3以后的数据进行update操作都减减1操作,不过这样做没什么意义吧
其一:给连续相同的type编号,即大 1 大2 大3 小1 小2……,这个需要用到用户变量
其二:编号后进行条件过滤
其三:分组统计
这三个可以写成一个SQL!