Показать сообщение отдельно
  #6  
Старый 30.09.2019, 00:50
Аватар для Guaho
Guaho Guaho вне форума
Начинающий
 
Регистрация: 27.08.2017
Сообщения: 173
Версия Delphi: Delphi7
Репутация: 10
По умолчанию

Я делал пару раз утилиты переноса связанных данных. Ничего страшно сложного нет. При переносе данных мастер-записи (равно как и слэйв-записи) получат новые коды (как автоинкремент назначит). В детальной таблице есть поле "Код мастер-записи" (можно называть его "ID", это как угодно). Нужно не просто скопировать данные двух таблиц, но ещё для записей подчинённой таблицы в упомянутое поле "Код мастер-записи" вбить новые коды, а именно коды мастера в таблице-приёмнике. А для этого надо перебрать все записи в подчинённой таблице-приёмнике, и при этом:
1. Найти такую же слэйв-запись в источнике и оттуда узнать код мастер-записи (Locate по основным полям).
2. Найти мастер-запись в источнике по её известному коду (Locate по полю "Код").
3. Найти эту же мастер-запись в приёмнике (Locate по основным полям) и получить её код.
4. Этот код вбить в поле "Код мастер-записи" приёмника.
Все эти манипуляции необходимы потому, что поле "Код", или "ID", идентифицирующее записи, - автоинкрементное, в итоге при переносе данных в приёмнике получатся совсем не такие коды записей, как в источнике, потому связь по кодам из источника в приёмнике не проканает.
Ответить с цитированием