首先祝大家新年好!
正题:
SQL数据库太大,而且每时每刻都在增加。使用select * form BM  等十分钟都没有查询结果。
使用查询最顶相关记录,结果很快(select top 300 * from BM 反映很快),现在想查询最新的记录,同样等十分钟没有结果,一直在查询。
有什么方法可以加速查询最新的记录?或有什么语句可以快速查询最新记录。谢谢!

解决方案 »

  1.   

    数据库大原因多,,,
    分表,,索引
    或分区表
    top300是只从头开始取300行,,不限制是取全部,,,自然前者快得没商量
    看需求
    索引的话,,,500万笔以内合理的索引得可以良好的处理,再多就看你表字段是否很多,
    再多就只有分表或做分区表
    大表对查询优化要求很大,,,即使有索引,,查询不优化也等于0
    问题多得去了
      

  2.   


    你在查询分析器里面直接sql语句要10分钟吗?
      

  3.   

    全表查询没有必要,难道你要把几百万的数据一下子取出来呈现给用户?
    还是从应用的设计着手解决吧========================================
    国产数据库 http://bbs.dameng.com
    ========================================
      

  4.   

    使用select * form BM  等十分钟都没有查询结果。这个就有点不正常。
    一、你可以试试 select count(1) from BM
    二、索引优化
    http://blog.csdn.net/downmoon/archive/2010/02/01/5277405.aspx
    跟踪:
    http://blog.csdn.net/downmoon/archive/2009/08/12/4440239.aspx
    三、表结构优化四、硬件改进,尤其是内存