一种保证速度的mysql库表查询写法

原创 2015年11月18日 15:07:01

如果一个Mysql库表达到百万数量级,那么使用普通的SQL语句写法会导致速度逐渐慢到难以忍受,下面是一种可以保证速度的写法。
假设表名称为entity,含有数百万条记录,有一个主键为自增id,另外两列为entityName和url,现在要读取表中的entityName

int total = getTotalCount();//获取记录总数
int limit = 1000;//每次读取的记录个数
int fetchSize = (total + limit - 1) / limit;
for(int i = 0; i < fetchSize; ++i) {//若程序中断,可以修改i的初始值,继续从断掉的地方继续运行
    int startIndex = i * limit;
    if (startIndex >= 10000) {
        sql = "select entityName from entity where id >= (select id from entity order by id asc limit "
             + startIndex + ",1) limit " + limit;
    } else {
        sql = "select entityName from entity order by id asc limit "
             + startIndex + ", " + limit;
    }
    //其余代码略
}

上述代码段的if和else提供了两种查询方法,if中为效率更高的分页查询写法,它先对表中的记录进行定位,然后从这个位置开始取数据;else中即为普通的查询写法,由limit限定每次查询的部分,随着数据的顺序读取,需要跨越的数据块越来越大,导致速度越来越慢。实际的应用表明在整个的查询过程中,第一种方法的速度比较快且稳定。

注意:在写select语句的时候,需要用到哪几列就select哪几列,比select *的效率高

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

表分区MySQL版本:5.5.11比5.1查询速度明显提高(4倍左右)

实验1   1、建表: create table `t_part_test`( `id` int NOT NULL default 0, `detail` char(32) NO...

mysql数据库表分区详解(数量过大的数据库表通过分区提高查询速度)

这篇文章主要介绍了MySQL的表分区,例如什么是表分区、为什么要对表进行分区、表分区的4种类型详解等,需要的朋友可以参考下 一、什么是表分区 通俗地讲表分区是将一大表,根据条件分割成若干个小表。m...

MySQL查询语句写法示例

Mysql模糊查询like效率,以及更高效的写法

在使用msyql进行模糊查询的时候,很自然的会用到like语句,通常情况下,在数据量小的时候,不容易看出查询的效率,但在数据量达到百万级,千万级的时候,查询的效率就很容易显现出来。这个时候查询的效率就...

C#委托的另一种写法

  • 2011-04-12 12:15
  • 375B
  • 下载

mysql limit分页查询优化写法

在mysql中进行分页查询时,一般会使用limit查询,而且通常查询中都会使用orderby排 序。但是在表数据量比较大的时候,例如查询语句片段limit 10000, 20,数据库会读取10020条...

Oracle、MYSQL、sql server和DB2分页查询写法

一、DB2:   DB2分页查询   SELECT * FROM (Select 字段1,字段2,字段3,rownumber() over(ORDER BY 排序用的列名 ASC) A...

mysql提高查询速度

1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。  2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)