posts - 33,  comments - 11,  trackbacks - 0

          數據庫中有個大表,需要查找其中的名字有重復的記錄id,以便比較。

          如果僅僅是查找數據庫中name不重復的字段,很容易

          1. SELECT min(`id`),`name`   
          2. FROM `table`   
          3. GROUP BY `name`;  

          但是這樣并不能得到說有重復字段的id值。(只得到了最小的一個id值)

          查詢哪些字段是重復的也容易

          1. SELECT `name`,count(`name`) as count   
          2. FROM `table`   
          3. GROUP BY `name` HAVING count(`name`) >1   
          4. ORDER BY count DESC;  

          但是要一次查詢到重復字段的id值,就必須使用子查詢了,于是使用下面的語句來實現MySQL大表重復字段查詢。

          1. SELECT `id`,`name`   
          2. FROM `table`   
          3. WHERE `name` in (   
          4.    SELECT `name`   
          5.    FROM `table`   
          6.    GROUP BY `name` HAVING count(`name`) >1  
          7. );  

          但是這條語句在mysql中效率太差,感覺mysql并沒有為子查詢生成零時表。

          于是使用先建立零時表

          1. create table `tmptable` as (  
          2.    SELECT `name`   
          3.    FROM `table`   
          4.    GROUP BY `name` HAVING count(`name`) >1  
          5. );  

          然后使用多表連接查詢

          1. SELECT a.`id`, a.`name`   
          2. FROM `table` a, `tmptable` t   
          3. WHERE a.`name` = t.`name`;  

          結果這次結果很快就出來了。

          用 distinct去重復

          1. SELECT distinct a.`id`, a.`name`   
          2. FROM `table` a, `tmptable` t   
          3. WHERE a.`name` = t.`name`;  
          posted on 2012-05-25 14:15 方濤升 閱讀(257) 評論(0)  編輯  收藏 所屬分類: j2ee
          <2012年5月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          常用鏈接

          留言簿(2)

          隨筆分類

          隨筆檔案

          文章分類

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 巴青县| 津市市| 凤翔县| 和龙市| 澎湖县| 灌南县| 兴业县| 邯郸县| 调兵山市| 广州市| 湘潭市| 铁岭市| 枞阳县| 永州市| 五大连池市| 阳谷县| 高青县| 宾阳县| 丹江口市| 兴山县| 邢台市| 潞西市| 如皋市| 武定县| 濮阳县| 历史| 繁昌县| 宽甸| 沂源县| 城步| 宝清县| 应城市| 彰化县| 郸城县| 阜新| 晋中市| 北宁市| 太仓市| 梅河口市| 远安县| 南安市|