| 
| 
 | Вопрос # 4 181/ вопрос открыт / | 
 |  Доброго времени суток, уважаемые эксперты! Есть связка БД Access + Delphi через ADO. Помогите создать запрос для квери, что бы удалялись все записи во всех таблицах  БД Access. 
|  |   Вопрос задал: 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
 
 |  
 Мини-форум вопросаМини-форум пуст. Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте. |