MYSQL“发送数据”每次显示不同的值

时间:2011-04-01 18:41:11

标签: mysql

我是一名学生,正在尝试测试项目的不同数据库的性能。 我试图做的是生成0-99999(通过多次自加入0-9数字表)并测量时间。我对我的结果感到惊讶,并且想知道是否有人可以帮助解释它们(它们如下所示)。

这是我的测试程序:

BEGIN

DECLARE vduration DECIMAL(8,4) DEFAULT 0;
DECLARE vid INT DEFAULT 0; 
DECLARE vcount INT DEFAULT 0;
DECLARE vprofilingid INT DEFAULT 0;
DECLARE a INT DEFAULT 0 ;

simple_loop: LOOP
     SET a = a+1;
     FLUSH QUERY CACHE;  

     SET profiling=1;
     SELECT n1.n + n2.n*10 + n3.n*100 + n4.n*1000 + n5.n*10000
     FROM
         baseline.num n1
       , baseline.num n2
       , baseline.num n3
       , baseline.num n4
       , baseline.num n5
     LIMIT 100000; 
     SET profiling=0;

     SELECT COUNT(*) INTO vcount FROM baseline.result;
     IF vcount=0 THEN
       SET vid=1;
     ELSE 
       SELECT MAX(Rid)+1 INTO vid FROM baseline.result;
     END IF; 

     SELECT MAX(DISTINCT(query_id)) INTO vprofilingid
     FROM information_schema.profiling;

     SELECT SUM(duration) INTO vduration
     FROM information_schema.profiling WHERE query_id=vprofilingid; 

     INSERT INTO baseline.result VALUES (vid, vduration); 

     IF a=5 THEN
       LEAVE simple_loop;
     END IF;
END LOOP simple_loop;             

END

结果:

RID     DURATION
8       0.0406
9       1.8610
10      1.8401
11      1.8558
12      1.8638

正在运行SHOW PROFILES会显示:

8   0.04059275  select n1.n+n2.n*10+n3.n*100+n4.n*1000+n5.n*10000 from baseline.num n1, baseline.num n2,baseline.num n3,baseline.num n4,baseline.num n5 Limit 100000
9   1.86098975  select n1.n+n2.n*10+n3.n*100+n4.n*1000+n5.n*10000 from baseline.num n1, baseline.num n2,baseline.num n3,baseline.num n4,baseline.num n5 Limit 100000
10  1.84006350  select n1.n+n2.n*10+n3.n*100+n4.n*1000+n5.n*10000 from baseline.num n1, baseline.num n2,baseline.num n3,baseline.num n4,baseline.num n5 Limit 100000
11  1.85582025  select n1.n+n2.n*10+n3.n*100+n4.n*1000+n5.n*10000 from baseline.num n1, baseline.num n2,baseline.num n3,baseline.num n4,baseline.num n5 Limit 100000
12  1.86381750  select n1.n+n2.n*10+n3.n*100+n4.n*1000+n5.n*10000 from baseline.num n1, baseline.num n2,baseline.num n3,baseline.num n4,baseline.num n5 Limit 100000

为什么第一次更快?这与我的假设相反。

我注意到SENDINT DATA

存在差异
SELECT * FROM information_schema.profiling
WHERE query_id > 7 and state = 'Sending data';

节目:

8     10    Sending data    0.040310
9     10    Sending data    1.860891
10    10    Sending data    1.839958
11    10    Sending data    1.855719
12    10    Sending data    1.863717

另外,如果我将循环设置为仅运行一次,则所有结果大约为0.04秒。我在这里做错了吗?我真的很困惑。

1 个答案:

答案 0 :(得分:1)

这是MySQL所有线程状态的链接。

http://dev.mysql.com/doc/refman/5.5/en/general-thread-states.html

请注意sending data上的部分:

  

发送数据

     

线程正在读取和处理SELECT语句的行,并将数据发送到客户端。因为在此状态期间发生的操作往往会执行大量磁盘访问(读取),所以它通常是给定查询生命周期中运行时间最长的状态。

由于sending data包含磁盘读取时间,因此值可能会有很大差异,具体取决于数据是在HDD缓存,RAM缓存,MySQL缓存等中。

您的第一个查询不会从磁盘读取任何数据,因此reading data + sending it步骤要快得多。