Я хотел бы сохранить имя пользователя с последней измененной строкой таблицы в качестве поля в каждой таблице.
У меня есть следующая настройка: пользователь входит в систему, веб-уровень вызывает некоторые компоненты EJB 3.0. Эти компоненты EJB создают и изменяют некоторые объекты JPA. Теперь я хотел бы, чтобы это имя пользователя (из веб-слоя) автоматически сохранялось в каждом объекте JPA (и строке базы данных), который создается или изменяется во время вызова метода EJB.
У меня есть такая таблица (то есть: каждая таблица имеет модификатор поля):
CREATE TABLE my_table (
some_data INTEGER,
modifier VARCHAR(20)
);
Автоматически я имею в виду, что мне не нужно вручную устанавливать имя пользователя для каждого объекта внутри методов EJB.
Вы можете добиться этого, сохранив имя пользователя в переменной ThreadLocal и выбрав имя пользователя из ThreadLocal в объекте JPA EntityListener. Однако это работает, только если вы используете локальный вызов EJB, он не будет работать с вызовами EJB, которые пересекают границы JVM. Я хотел бы, чтобы эта работа выполнялась через удаленные вызовы методов EJB.
Возможно ли это вообще?
Я использую Weblogic Server 10.3, EJB3.0 и EclipseLink JPA. Мне также интересно узнать, работает ли это с другими реализациями JPA.