Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.05.16;
Скачать: CL | DM;

Вниз

База не меняет размер...   Найти похожие ветки 

 
3APA3A ©   (2004-04-14 23:20) [0]

FireBird 1.5.ххх
 В базе одна таблица, в ней порядка 2000000 записей, занимает около 125 Мб...
 после выполнения запроса

 IBQuery1.SQL.Text := "delete from table1";
 IBQuery1.ExecSQL;
 
 1) запрос выполнялся около 5 минут
 2) размер самой базы увеличился до 141 Мб
 3) записей в таблице не осталось, то есть запрос выполнился верно...
 Помогите разобраться...


 
Jack128 ©   (2004-04-14 23:37) [1]

База в Ib не может уменьшиться в размерах, только увеличить..При удалении записи только помечаются как удаленные, но физически не удаляются из базы. Сделай Backup/Restore и будет тебе счастье.


 
bds   (2004-04-15 11:04) [2]

Уточнение. Страницы БД, занятые данными, помечаются как неиспользуемые, а не сами записи. При добавлении записей на эти страницы поверх старых данных будут писаться новые. Размер же действительно измениться только после Backup/Restore.


 
LaidBack   (2004-04-15 11:07) [3]


>  2) размер самой базы увеличился до 141 Мб


Увеличился из-за добавления записей в журнал транзакций + изменение списка свободных страниц.


 
3APA3A ©   (2004-04-15 22:23) [4]

Со страницами для данных понятно...
А для транзакций - СУБД выделяет страницы, использует их, а потом, не удаляет а тоже помечает как неиспользуемые?


 
Jack128 ©   (2004-04-15 22:27) [5]


> Уточнение. Страницы БД, занятые данными, помечаются как
> неиспользуемые, а не сами записи
Вот какой вопрос: например я удалил одну запись, а на этой странице, кроме этой записи еще десяток. Как сервер узнает, что эта запись удалена, а другие нет??


 
bds   (2004-04-16 11:14) [6]

Внутри базы есть Pointer-page - страницы указателей на данные и
Data-page - страницы данных.  Данные расположены на Data-page.
У каждого блока данные на Data-page есть 2 флага:
Old version (версия актуальна для какой либо транзакции) и
Dead record (блок данных удален (не используется))..
При удалении выставляется Dead record и все. Сервер "видя" Dead record может использовать это место для новых данных.
Для транзакций - страницы не выделяются (зачем?). Есть счетчик транзакций + номер последней заинтересованной транзакции (хранятся в заголовке БД - header-page). Страницы выделяюся только под данные, указатели и индексы (index page и index B-tree page).



Страницы: 1 вся ветка

Текущий архив: 2004.05.16;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.042 c
1-1083579824
Denis_Visma
2004-05-03 14:23
2004.05.16
Выделить итем в DBLookUpComboBox


14-1082719510
MPS
2004-04-23 15:25
2004.05.16
Red Hat загружаемый с DVD-RW диска. Возможно ли?


3-1082555269
}|{yk
2004-04-21 17:47
2004.05.16
Master-detail в FIBPlus


1-1083071073
Alexus12
2004-04-27 17:04
2004.05.16
класс и динамический массив


14-1082704783
*Pavel
2004-04-23 11:19
2004.05.16
Есть ли выход из интернета ?