Новости
Документация
Download
Webboard
Поиск
FAQ/ЧаВо
Обратная связь




MySQL.RU - Webboard



Вернуться
update большого числа записей (AlexVS) 01/04/2007 - 00:35:52



From: AlexVS - 01/04/2007 - 00:35:52
Subject:update большого числа записей
-----------------
Есть таблица:
| uniqs | CREATE TABLE `uniqs` (
`id` int(10) unsigned NOT NULL auto_increment,
`a` smallint(5) unsigned NOT NULL,
`u` char(16) NOT NULL default '0',
`g` char(4) NOT NULL default '0',
`last_time` timestamp NOT NULL default '0000-00-00 00:00:00',
PRIMARY KEY (`id`),
UNIQUE KEY `uniqs_a_u_g` USING BTREE (`a`,`u`,`g`)
) ENGINE=MyISAM AUTO_INCREMENT=6090148 DEFAULT CHARSET=koi8u |

Необходимо в поле last_time записывать время последнего обращения к записи. Для ускорения в скрипте (perl) веду хэш (id -> time) и после накопления в нём 400 000 записей в цикле говорю: update uniqs set last_time = time where id = id.
Но эта процедура длится порядка 12 минут, что есть недопустимо долго. При это загрузка проца 0, а винта - четверть от максимального.

Как-то можно увеличить производительность?

З.Ы.: Блокировка таблиц не даёт ускорени, т.к. по этому полю нет индексации.

З.Ы.Ы.: time вставляется в формате: '2007-03-31 23:12:59', может стоит скармливать unixtimestamp?


[Это сообщение - спам!]

Последние сообщения из форума

Уважаемые посетители форума MySQL.RU!
Убедительная просьба, прежде чем задавать свой вопрос в этом форуме, обратите внимание на разделы:
- ответы на наиболее часто задаваемые вопросы - FAQ
- раздел документация
- раздел поиск по сообщениям форума и документации
Также, старайтесь наиболее подробно указывать свою ситуацию (версию операционной системы, версию MySQL, версию программного обеспечения, по которому возникает вопрос, текст возникающих ошибок, и др.)
Помните, чем конкретнее Вы опишете ситуацию, тем больше шансов получить реальную помощь.
 Имя:
 E-mail:
 Тема:
 Текст:
Код подтверждения отправки: Code
31196



РЕКЛАМА НА САЙТЕ
  Создание сайтов | |