标签归档:SQL

MySQL 先排序再分组的问题

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 … 继续阅读

发表在 Excellence Article | 标签为 , | 留下评论

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 … 继续阅读

发表在 Database | 标签为 , | 留下评论

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 ( … 继续阅读

发表在 Programming | 标签为 , | 留下评论