sid     | bigint(20) unsigned          | NO   | PRI | NULL    | auto_increment |
| userid  | int(10) unsigned             | NO   | MUL | 0       |                |
| sip     | bigint(12) unsigned zerofill | NO   | MUL | NULL    |                |
| stime   | int(10) unsigned             | NO   | MUL | NULL    |                |
| stype   | tinyint(1) unsigned          | NO   | MUL | NULL    |                |
| keyword | char(80)                     | NO   | MUL | NULL    |           
DELETE FROM search WHERE stime<='1325350861';
     用这一条数据,我删了很久,都没有反映,请问一下,我该怎么操作一下,实现我的需求。

解决方案 »

  1.   

    分批
    mysql> delete from bit_dcsval where insert_datetime<'2009-10-01' order by insert_datetime limit 10000;
    Query OK, 10000 rows affected, 1 warning (3 min 48.40 sec)上面是网上的例子
      

  2.   

    如果6千万数据中,10天的数据仅仅占一小部分,建议将这部分select into到一张新表里,然后将原来的表truncate掉,之后再将新表rename成原来的表顺利的话,估计只要几秒钟。truncate操作是效率最高的,当然也不可恢复。
      

  3.   

    INSERT INFO search_tmp SELECT * FROM search WHERE stime>='1329926400';
    TRUNCATE TABLE search;
    INSERT INTO search SELECT * FROM search_tmp;
    把数据导入进原表出错。
      

  4.   

    出的是什么错?DELETE TABLE search;
    RENAME TABLE search_tmp TO search;这样呢?