-
个人简介:
PHP开发者,高可用性、分布式集群实践者,伪Python、GAE开发者,伪Linux系统管理员,伪MySQL管理员
2009年8月至今服务于阿里巴巴云计算公司
2008年8月至2009年7月31日服务于博客大巴
-
归档
- 2012 年一月
- 2011 年十一月
- 2011 年九月
- 2011 年八月
- 2011 年七月
- 2011 年六月
- 2011 年五月
- 2011 年三月
- 2011 年二月
- 2011 年一月
- 2010 年十二月
- 2010 年十一月
- 2010 年十月
- 2010 年九月
- 2010 年八月
- 2010 年七月
- 2010 年六月
- 2010 年五月
- 2010 年四月
- 2010 年三月
- 2010 年二月
- 2010 年一月
- 2009 年十二月
- 2009 年十一月
- 2009 年十月
- 2009 年九月
- 2009 年八月
- 2009 年七月
- 2009 年六月
- 2009 年五月
- 2009 年四月
- 2009 年三月
- 2009 年二月
- 2009 年一月
- 2008 年十二月
- 2008 年十一月
- 2008 年十月
- 2008 年九月
- 2008 年八月
- 2008 年七月
- 2008 年六月
- 2008 年五月
- 2008 年四月
- 2008 年三月
- 2008 年二月
- 2008 年一月
- 2007 年十二月
- 2007 年十一月
- 2007 年四月
-
杂项
标签归档: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 … 继续阅读
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 … 继续阅读
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 ( … 继续阅读