Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Переиндексация Базы Данных

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
Hastur



Зарегистрирован: 14.06.2007
Сообщения: 24

СообщениеДобавлено: Ср Янв 16 2008 17:48    Заголовок сообщения: Переиндексация Базы Данных Ответить с цитатой

Я вообще не уверен что эта операция над БД называется переиндексацией. Суть в общем такова - в нескольких таблицах БД есть автоинкрементные поля, через какой-то промежуток работы базы получается ситуёвина когда индексы становятся очень большими но при это в следствие удаления некоторых картежей пропущено много промежуточных номеров. Вот я и хочу сделать переиндексацию чтобы нормализовать индексы а т.к. почти всегда такие поля являются ключевыми и переходят во многии другие таблицы как вторичные ключи то придётся изменять очень много данных в разных таблицах. Думается что это будет довольно долго и муторно в смысле разработки такой операции.
Кто-нибудь решал такую задачу? Поделитесь опытом плз
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
mad_alexx



Зарегистрирован: 14.01.2005
Сообщения: 154
Откуда: Иркутск

СообщениеДобавлено: Ср Янв 23 2008 06:23    Заголовок сообщения: Ответить с цитатой

Конкретная реализация зависит от СУБД. Например, для MySQL можно сделать так:
Код:

create table tbl1 (
  id int unsigned not null primary key auto_increment,
  s varchar(10)
);

create table tbl2 (
  id int unsigned not null primary key auto_increment,
  s varchar(10)
);

добавить/удалить в tbl1

insert into tbl2 (s) select s from tbl1 order by id;
.
Так мы перенесём данные из таблицы tbl1 в таблицу tbl2, причём id будет увеличиваться последовательно. Потом удалить tbl1 и аналогично перенести из tbl2 в tbl1.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...