Вставка новой записи через буфер
{codecitation class=»brush: pascal; gutter: false;» width=»600px»}
Автор: Eryk Bottomley
Один программер любил компьютеры. Пока его за этим не застукали…
Table2.Insert;
Move(Table1.ActiveBuffer^,Table2.ActiveBuffer^,Table1.RecordSize);
{При необходимости назначаем новый первичный ключ}
Table2.FieldByName(‘Primary Key’).AsWhatever := whatever;
Table2.Post;
…если вы уверены в том, что нарушение ключа произойти не может, то можно вырезать это для дальнейшего использования:
DbiInsertRecord(Table2.Handle,dbiNOLOCK,Table1.ActiveBuffer);
…конечно, это «обходит» VCL, т.к., чтобы увидеть потом новую запись, необходимо сделать TTable.Refresh.
{/codecitation}