Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 4 181

/ вопрос открыт /

Доброго времени суток, уважаемые эксперты! Есть связка БД Access + Delphi через ADO. Помогите создать запрос для квери, что бы удалялись все записи во всех таблицах БД Access.

GAZ Вопрос ожидает решения (принимаются ответы, доступен мини-форум)

Вопрос задал: GAZ (статус: Посетитель)
Вопрос отправлен: 19 мая 2010, 07:26
Состояние вопроса: открыт, ответов: 2.

Ответ #1. Отвечает эксперт: Dron

Здравствуйте, GAZ!
Не уверен, что есть способ удалить все записи во всех таблицах одним запросом. Традиционно делается так:

DELETE * FROM table_name
Либо
TRUNCATE TABLE table_name
Соответственно, нужно перебрать все таблицы в БД и выполнить для каждой такой запрос.

Ответ отправил: Dron (статус: Студент)
Время отправки: 19 мая 2010, 10:43

Ответ #2. Отвечает эксперт: Вадим К

Здравствуйте, GAZ!
Удалить одним запросом никак не получиться. (может для каких то отдельных БД и получиться, но в целом - нет). Поэтому берем правильное решение - составляем список всех таблиц (а я уже давал ответ на подобный вопрос, Ваш, между прочим, - https://expert.delphi-int.ru/question/4095/ ) и для каждой таблицы выполняем DELETE FROM table_name;
Но этот способ имеет один недостаток. Если в таблице были индексы (в виде автоинкрементов), то они не обнуляются. В таких случаях применяют более радикальный метод - вначале через DROP TABLE удаляют таблицы, а потом создают их с помощью CREATE TABLE.

Ответ отправил: Вадим К (статус: Академик)
Время отправки: 19 мая 2010, 10:46


Мини-форум вопроса

Мини-форум пуст.

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:27
Выполнено за 0.02 сек.