![Заполните внешний ключ, используя выпадающий список/комбо в форме](https://rvso.com/image/1475804/%D0%97%D0%B0%D0%BF%D0%BE%D0%BB%D0%BD%D0%B8%D1%82%D0%B5%20%D0%B2%D0%BD%D0%B5%D1%88%D0%BD%D0%B8%D0%B9%20%D0%BA%D0%BB%D1%8E%D1%87%2C%20%D0%B8%D1%81%D0%BF%D0%BE%D0%BB%D1%8C%D0%B7%D1%83%D1%8F%20%D0%B2%D1%8B%D0%BF%D0%B0%D0%B4%D0%B0%D1%8E%D1%89%D0%B8%D0%B9%20%D1%81%D0%BF%D0%B8%D1%81%D0%BE%D0%BA%2F%D0%BA%D0%BE%D0%BC%D0%B1%D0%BE%20%D0%B2%20%D1%84%D0%BE%D1%80%D0%BC%D0%B5.png)
Я хотел бы заполнить поле внешнего ключа в одной таблице с помощью раскрывающегося списка, где значения, которые видит пользователь, являются не идентификаторами, а полем описания из внешней таблицы.
Рассмотрим следующую схему:
create table people (
id int identity primary key,
name varchar(250),
job_id int
);
create table jobs (
id int identity primary key,
description varchar(250)
);
insert into jobs(description) values 'foo';
insert into jobs(description) values 'bar';
Я указал связь внешнего ключа в окне связей:
И я бы хотел, чтобы пользователь видел это jobs.description
при создании нового person
через форму.
Но я не вижу, как это сделать. Если я создаю форму на основе запроса, который объединяет две таблицы, то я не могу создать новые данные, а если я создаю форму на основе people
, то Subform based on existing relation
опция становится серой:
В Access это легко сделать с помощью мастера форм:
Как этого добиться в LibreOffice/OOo Base?
решение1
Это невозможно сделать с помощью мастера форм. Связанные формы — это отвлекающий маневр.
Но это может быть сделановесьмалегко, следующим образом.
- Используйте мастер форм, чтобы заполнить форму как можно шире, используя
people
только поля из таблицы. - Отредактируйте форму в режиме конструктора (*подсказка: иконка совершенно не интуитивно понятна, но выглядит так:
)
- Добавьте элемент управления «список» в форму (примечание: это не выпадающий список, это что-то другое в Base). Это откроет мастер, который проведет вас через все остальное.
- В
Choose the table from which the data should be used as basis for the list content
, выберитеjobs
. - Выберите
description
в качествеDisplay field
. - Под
Field from the Value Table
выборомjob_id
и подField from the List Table
выборомid
.
Вот и все! Теперь раскрывающийся список будет работать именно так, как и ожидалось:
Если вам не нравятся мастера, вы можете вручную отредактировать элемент управления «Список» следующим образом:
- Добавьте свой список, затем закройте мастер. Щелкните значок «Управление», который представляет собой шестеренку. (Это также не имеет смысла.)
- Введите информацию следующим образом, где в поле «Содержимое списка» указано «ВЫБЕРИТЕ «ОПИСАНИЕ», «ИДЕНТИФИКАТОР» ИЗ «ЗАДАНИЯ». Обратите внимание, что поле, которое вы хотите, чтобы пользователь видел,долженидет первым, и что «Привязанное поле» имеет нулевую индексацию и должно ссылаться на столбец идентификатора.
Вот и все!