我对 MySQL 有一个非常奇怪的情况。
举个例子:一个包含 15000 个条目的表
CREATE TABLE `temp_geonis_export` (
`auto_id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
`obj_id` VARCHAR(10),
`gis_id` VARCHAR(45),
`letzteReinigung_id` VARCHAR(10),
INDEX `Index_2`(`gis_id`),
PRIMARY KEY (`auto_id`)
)
ENGINE = InnoDB;
现在我正在更新表中的 14000 行。我知道,这是一个很丑陋的陈述,很容易被重写,但这不是问题......
Update temp_geonis_export as temp
inner join (
Select gis_id, obj_id from
(
Select abw.gis_id, abw.bezeichnung, erh.obj_id
from od_abwasserbauwerk as abw
inner join od_erhaltungsereignis as erh on erh.fs_abwasserbauwerk = abw.obj_id and erh.status = 2
inner join od_reinigung as unter on unter.obj_id = erh.obj_id
order by fs_abwasserbauwerk asc, erh.zeitpunkt asc
) as alleSortiert group by alleSortiert.gis_id
) as naechsteRein on temp.gis_id = naechsteRein.gis_id
set temp.naechsteReinigung_id = naechsteRein.obj_id;
现在,如果我在我们的开发服务器上运行更新语句,大约需要 1 秒。在我们的一台生产服务器上,这需要 90 秒!!
这些是我的观察:
- Handler_read_rnd_next 101000(开发)、266177000(生产)
- 生产系统上的 CPU 使用率非常高(由于上述观察)
- 两个系统上几乎没有磁盘 IO
- 当我重写更新查询并将子查询的输出存储到临时表中时,更新语句在两个系统上都很快
由于观察,我的结论是,出于某种原因,我们的生产服务器必须对每个更新的行执行全表扫描。开发服务器没有。一定是配置问题,因为我们的服务器都是5.1.25,硬件也差不多。
您是否有线索,我必须在我们的生产服务器上进行哪些更改才能使其性能更好?
谢谢你的帮助