Arhn - архитектура программирования

Поведение при доступе — он хочет обновить записи, я хочу, чтобы он вставлял новые, отслеживал старые по отметке времени

Я разрабатываю базу данных, в которой я хочу отслеживать изменения в своих таблицах, в данном случае в таблице «человек», так что то, что отображается в моем пользовательском интерфейсе Access как редактирование записи человека, на самом деле появляется в моем бэкэнде PostgreSQL как новая запись с отметкой времени и полем имени пользователя, отражающими время и человека, внесшего это редактирование.

Прежде всего, я никогда не пытался создать подобный дизайн, поэтому было бы неплохо получить некоторую уверенность в том, что я делаю это разумно. Однако мой главный вопрос заключается в том, как это реализовать. В общем, формы Access, кажется, очень сильно предназначены для редактирования записей, и я не уверен, как я могу чисто изменить его поведение, чтобы вместо этого вставить новые.

Насколько я понимаю, событие BeforeUpdate срабатывает перед обновлением на уровне базы данных. Что бы я хотел сделать, так это отредактировать метод BeforeUpdate моей формы с помощью кода, например:

  1. Отменить обновление базы
  2. Обновите отметку времени в Access для записи, с которой он работает.
  3. Обнулите поле recordid из записи, которая является первичным ключом auto_increment, так что при вставке новый идентификатор записи будет назначен автоматически.
  4. Вставьте новую копию записи, с которой я работаю в Access
  5. Если необходимо (я так думаю?), укажите в моей форме доступа на только что вставленную новую запись (кстати, как мне найти вставленную новую запись? Могу ли я получить ссылку на нее во время вставки, или на автоматически увеличивающийся первичный ключ, который был сгенерирован?)

Спасибо за любую помощь, которую может предоставить любой.


  • Я бы сказал, что это не очень хорошая идея. Но вы можете захотеть изучить режим ввода данных в формах доступа. 29.07.2011

Ответы:


1

Я бы позволил Access обновить свои таблицы и просто создать оператор вставки в ваш сервер PostgreSQL. Вы можете использовать его как свой журнал. Попытка отключить текущую запись в доступе кажется сложной и ненужной. Изменение первичного ключа необязательно и должно использоваться для ссылки на измененные записи данных в другой базе данных.

Вы можете использовать VBA в коде формы и просто создать еще одну запись с текущими данными, но использовать функцию Now() для значения метки времени.

28.07.2011
  • +1 Вы можете сделать это на стороне PostGreSQL, используя вместо триггера: разработчик .postgresql.org/pgdocs/postgres/sql-createtrigger.html 28.07.2011
  • Хорошо, поэтому вместо того, чтобы перехватывать редактирование и вставлять его как новую запись, я просто использую триггер Postgres, чтобы убедиться, что перед редактированием записи я вставляю копию оригинала (которой будет назначен новый идентификатор записи, которого Access не делает). в любом случае нужно знать). Таким образом, Access продолжает работать только с одной записью, и ему даже не нужно знать, что происходит архивирование. Это имеет смысл, я думаю! 28.07.2011
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..