group是分组,想先排序如何办? 建一个表试试 – – 表的结构 `test` – CREATE TABLE IF NOT EXISTS `test` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(16) NOT NULL, `phone` int(11) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; – – 导出表中的数据 `test` – INSERT INTO `test` (`id`, `name`, `phone`) VALUES (1, ‘a’, 1234), (2, ‘a’, 3333), (3, ‘b’, 555),… Read more »
Posts Tagged: SQL
mysql 删除表中的重复记录,只保留其中一条
MySQL中漏掉了40%左右的数据,寻找这个错误的代价是花了三天,将所有的代码重新检查了一遍,由于代码不是我写的,看得晕头转向,上苍保佑,我还不算太笨,最终找到了原因,不过接着就碰到另外一个问题,找回的数据中存在重复,而且在无法在重复的健上建立唯一,于是我想了一个最笨的方法 SELECT * FROM sub_new WHERE email IN ( SELECT email FROM sub_new GROUP BY email HAVING COUNT(email) > 1 ) 这种算法是最傻也是最没出息的算法,在数量在1W的时候还可以接受,到10W就要两分钟了,到50W就死在那里了,所以告诫那些跟我一样天资不算聪明的人,数据量比较大的时候千万别用这种方法,这种类似冒泡排序的算法复杂度是O(n^2),如果你有10W条记录,你自己乘一下吧 接着又想了另外一个方法,虽然机械了点,不过效率非常之高,分三步走: CREATE TABLE tmp AS SELECT * FROM youtable GROUP BY name DROP TABLE youtable ALTER TABLE tmp… Read more »
SQL语句跨表查询问题
小生不才,一年前学过SQL皮毛,如今除了会一些简单的增删改查语句之外,其他的都还回去了,近日碰到一个问题: 有 A ,B,C 三张表,A 中存放一个id、comboid,combname,B中有 id,comboid,sid,C 中有sid,sname,B表的作用其实是相当于关联A和C的作用,首先在A中得到一个唯一的comboid,然后通过comboid在B中查询sid,再通过sid去C中查询对应的sname,问题就出在这里,如果comboid和sid是一一对应,那很好办,只要 SELECT sname FROM c WHERE sid = ( SELECT sid FROM b WHERE comboid = (SELECT comboid FROM a WHERE comboname=@comboname) ); 但事实上B中的关系是多对多的关系,一个comboid对应多个sid,这两天中我甚至写出好几个超级复杂的SQL查询语句,包括用到JOIN等连接操作和合并表,还有先建成视图,然后查询之类 实际上SQL内建了一个关键词“in”,这个词非常的有用,只要将上面的语句改一处,就可以适应返回结果不唯一的嵌套查询,代码如下: SELECT sname FROM c WHERE sid IN ( SELECT sid FROM b WHERE comboid = (SELECT comboid FROM a WHERE comboname=@comboname) ); 另外说明一下,本语句只在SQL… Read more »
Recent Comments