我是一名学生,正在尝试测试项目的不同数据库的性能。 我试图做的是生成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秒。我在这里做错了吗?我真的很困惑。
答案 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
步骤要快得多。