Справочник функций

Ваш аккаунт

Войти через: 
Забыли пароль?
Регистрация
Информацию о новых материалах можно получать и без регистрации:

Почтовая рассылка

Подписчиков: -1
Последний выпуск: 19.06.2015

TBlobField и Access

1.8K
09 июля 2007 года
rSolanov
106 / / 04.05.2005
Помогите, пожалуйста решить одну задачу:
Необходимо удалить картинку из БД.
Код:
BlobField.Clear;
Но удаляется лишь ссылка на эту картинку и в таблице картинка пропадает, а сам файл базы Access в объеме не уменьшается (сама картинка не удаляется). Помогает только Сервис-Служебные программы-Сжать и восстановить базу данных.
У меня есть идея только такого решения: сначала делаем Clear, а потом через COM-интерфейс выполнить "Сжать и восстановить базу данных", но ниодного COM-интерфейса в справке я не нашёл.
Знаете ли вы такой COM-интерфейс?
Есть ли другой способ решения этой проблемы?
302
19 июля 2007 года
Sagittarius
648 / / 12.04.2003
Этот COM-интерфейс - сам Access.

Если подумать, зачем СУБД сжимать файл БД после того, как оттуда удалена картинка? Это пустая трата времени. Картинка, например, может находиться в середине файла БД, и чтобы сжать файл, надо передвинуть весь "хвост". Выгодее впоследствии в освободившееся место записать другие данные.
1.8K
26 июля 2007 года
rSolanov
106 / / 04.05.2005
Спасибо за совет, но я решил эту проблему так:
Изменил поле для хранения изображений с OLE на "числовой" и записываю туда результат вычисления хеш-функции (цифровой отпечаток файла изображения). В отдельную папку копирую файл изображения и определяю наименование файла по тому же результату хеш-функции.
Теперь, когда я перемещаюсь к определенной записи в таблице, из поля вытаскиваю наименование файла, а по наименованию и сам файл изображения и произвожу с ним все необходимые действия.
В результате у меня появилась возможность хранить файлы практически неограниченные в объеме и при этом приложение не зависает при открытии набора данных.
Реклама на сайте | Обмен ссылками | Ссылки | Экспорт (RSS) | Контакты
Добавить статью | Добавить исходник | Добавить хостинг-провайдера | Добавить сайт в каталог