Как в аксессе сделать связь один ко многим
Перейти к содержимому

Как в аксессе сделать связь один ко многим

  • автор:

Как создать множественную связь один-ко-многим между двумя таблицами в ACCESS

введите сюда описание изображения

Подскажите пожалуйста, как сделать подобную связь? В результате я хочу получить нарисованную связь. Просто протянуть связь не получается, т.к. ругается на целостность данных. Конкретно мне надо поставить зависимость между экземплярами «id_сети», для этого я вынес их в отдельную таблицу, но от одного ключевого атрибута я не могу поставить зависимость к составному ключу второй таблицы.

Отслеживать

51.2k 86 86 золотых знаков 266 266 серебряных знаков 505 505 бронзовых знаков

задан 4 мар 2016 в 12:37

93 1 1 серебряный знак 12 12 бронзовых знаков

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

4 мар 2016 в 13:13

Очень странная, на мой взгляд таблица «Поставщик_покупатель». Она одновременно содержит как информацию о сущностях, так и связь этих сущностей. А Вы хотите эти пары еще и к сетям привязать? Я бы серьёзно задумался над архитектурой и над нормальной формой такой БД. Но если, хотите все-таки связать, то в этой таблице надо добавить поле «id_сети_ref» как ссылку (вторичный ключ) на «Id_сети»

Руководство по межтабличным связям

Одной из целей создания хорошей структуры базы данных является устранение избыточности (повторения) данных. Для этого нужно распределить данные по нескольким отдельным тематически организованным таблицам, чтобы каждый факт был представлен один раз. В приложении Access будет предоставлен способ сбора разбросанных данных — это делается путем помещения общих полей в связанные таблицы. Чтобы корректно выполнить это действие, нужно понять взаимосвязи между таблицами и описать эти взаимосвязи в базе данных.

В этой статье

  • Введение
  • Типы связей между таблицами
  • Зачем создавать связи между таблицами?
  • Понятие о целостности данных
  • Просмотр связей между таблицами

Введение

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

1. Эта форма содержит данные из таблицы клиентов,

4. и сведений о заказах.

Имя клиента в поле Плательщик получено из таблицы «Клиенты», значения кода заказа и даты заказа — из таблицы «Заказы», наименование товара — из таблицы «Товары», а цена и количество — из таблицы «Заказано». Чтобы можно было передать данные в форму, эти таблицы связаны друг с другом несколькими способами.

В приведенном примере поля в таблицах должны быть согласованы таким образом, чтобы отображать сведения об одном и том же заказе. Это согласование осуществляется путем установления связей между таблицами. Связь между таблицами устанавливает отношения между значениями в ключевых полях — часто между полями, имеющими одинаковые имена в обеих таблицах. В большинстве случаев с первичным ключом одной таблицы, являющимся уникальным идентификатором каждой записи, связывается внешний ключ другой таблицы. Например, для связывания сотрудников с заказами, за которые они отвечают, можно создать связь между полями «Код сотрудника» в таблицах «Сотрудники» и «Заказы».

1. Поле «Код сотрудника» отображается в двух таблицах: как первичный ключ.

2. и как внешний ключ.

Типы связей между таблицами

В Access есть три типа связей между таблицами.

  • Связь «один-ко-многим» Рассмотрим базу данных, в которой учитываются заказы, включающую таблицы «Клиенты» и «Заказы» в качестве примера. Клиент может разместить любое количество заказов. Следовательно, у любого клиента, представленного в таблице «Клиенты», может быть много заказов, представленных в таблице «Заказы». Поэтому связь между таблицами «Клиенты» и «Заказы» — это отношение «один-ко-многим». Чтобы создать отношение «один-ко-многим» в структуре базы данных, добавьте первичный ключ на стороне «один» в таблицу на стороне «многие» в виде дополнительного поля или полей. В данном примере необходимо добавить новое поле — поле «Код» из таблицы «Клиенты» — в таблицу «Заказы» и назвать его «Код клиента». После этого Access сможет использовать номер «Код клиента» из таблицы «Заказы» для поиска клиента каждого заказа.
  • Связь «многие-ко-многим» Рассмотрим связь между таблицами «Товары» и «Заказы». Отдельный заказ может включать несколько товаров. С другой стороны, один товар может входить в несколько заказов. Таким образом, для каждой записи в таблице «Заказы» может существовать несколько записей в таблицы «Товары». Таким образом, для каждой записи в таблице «Заказы» может существовать несколько записей в таблице «Заказы». Эта связь называется отношением «многие-ко-многим». Обратите внимание, что для определения существующей схемы отношений «многие ко многим» между вашими таблицами, очень важно рассматривать обе стороны отношений. Чтобы представить связь «многие-ко-многим», нужно создать третью (связующую) таблицу, в которой она разбивается на две связи «один-ко-многим». Первичные ключи двух таблиц вставляются в третью таблицу. В результате в третьей таблице сохраняются все экземпляры связи. Например, таблицы «Заказы» и «Продукты» имеют связь «многие-ко-многим», определяемую путем создания двух связей «один-ко-многим» в таблице «Заказано». В одном заказе может быть много продуктов, и каждый продукт может быть указан во многих заказах.
  • Связь «один-к-одному» При отношении «один-к-одному» каждая запись в первой таблице может иметь не более одной связанной записи во второй таблице, и наоборот. Отношения этого типа используются нечасто, поскольку обычно сведения, связанные таким образом, хранятся в одной таблице. Отношение «один-к-одному» используется для разделения таблицы, содержащей много полей, с целью отделения части таблицы по соображениям безопасности, а также с целью сохранения сведений, относящихся к подмножеству записей в главной таблице. После определения такого отношения у обеих таблиц должно быть общее поле.

Зачем создавать связи между таблицами?

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

  • Связи между таблицами предоставляют сведения для структурирования запросов Для работы с записями из нескольких таблиц часто приходится создавать запросы, соединяющие таблицы. Запрос сопоставляет значения в поле первичного ключа первой таблицы с полем внешнего ключа второй таблицы. Например, чтобы получить строки, в которых перечисляются все заказы для каждого из клиентов, можно создать запрос, соединяющий таблицу «Клиенты» с таблицей «Заказы» на основе поля «Код клиента». В окне «Схема данных» можно вручную указать поля для соединения. Но если связь между таблицами уже существует, Access использует соединение по умолчанию на основе существующей связи между таблицами. Кроме того, при использовании одного из мастеров запросов Access использует сведения об уже определенных связях между таблицами, чтобы предоставить пользователю выбор и подставить в параметры свойств соответствующие значения по умолчанию.
  • Связи между таблицами предоставляют сведения для структурирования форм и отчетов При создании формы или отчета в Access используются сведения об уже определенных межтабличных связях, чтобы предоставить пользователю выбор и предварительно заполнить параметры свойств соответствующими значениями по умолчанию.
  • Связи между таблицами — это та основа, с помощью которой можно обеспечить целостность данных, чтобы в базе данных не было потерянных записей. Потерянная запись — это запись со ссылкой на несуществующую запись (например, запись заказа со ссылкой на отсутствующую запись клиента). При создании базы данных сведения распределяются по таблицам, в каждой из которых есть первичный ключ. После этого к связанным таблицам добавляются внешние ключи, имеющие ссылки на первичные ключи. Эти пары из внешнего и первичного ключей формируют основу для связей между таблицами и многотабличных запросов. Поэтому важно, чтобы ссылки «внешний ключ — первичный ключ» оставались синхронизированными. Целостность данных, которая зависит от связей в таблице, гарантирует, что ссылки остаются синхронизированными.

Понятие о целостности данных

При создании базы данных сведения распределяются по множеству тематически организованных таблиц, чтобы свести к минимуму избыточность данных. После этого в Access предоставляются средства сбора разбросанных данных путем создания в связанных таблицах общих полей. Например, чтобы создать связь «один-ко-многим», добавьте первичный ключ из таблицы на стороне «один» как дополнительное поле в таблицу на стороне «многие». Чтобы соединить данные, Access подставляет значение из таблицы на стороне «многие» в соответствующее поле таблицы на стороне «один». Таким образом, значения таблицы на стороне «многие» связаны с соответствующими значениями на стороне «один».

Предположим, между таблицами «Грузоотправители» и «Заказы» существует связь «один-ко-многим», и нужно удалить грузоотправителя. Если у грузоотправителя, которого нужно удалить, есть заказы в таблице «Заказы, они станут потерянными записями после удаления записи грузоотправителя. В таблице «Заказы» останется код грузоотправителя, но он будет недействителен, поскольку запись, на которую он ссылается, уже не существует.

Задача сохранения целостности данных состоит в предотвращении появления потерянных записей и поддержании ссылок в синхронизированном состоянии, чтобы описанная выше гипотетическая ситуация никогда не возникла.

Обеспечение целостности данных включается для конкретного отношения между таблицами. После активации, Access будет отклонять любые операции, нарушающие целостность данных для этой межтабличной связи. Это означает, что Access будет отклонять как любые обновления, изменяющие целевой объект ссылки, так и удаление такого целевого объекта. Возможно, у вас может быть полностью допустимая потребность в изменении первичного ключа для поставщика, у которого есть заказы в таблице «Заказы». В этом случае необходимо, чтобы Access выполнил автоматическое обновление всех задействованных строк в рамках одной операции. Таким образом, Access гарантирует, что обновление будет полностью завершено, а база данных не будет находиться в несогласованном состоянии, когда некоторые строки обновлены, а другие — нет. Для этого в Access имеется параметр Каскадное удаление связанных записей. Если при включении обеспечения целостности данных был включен параметр Каскадное удаление связанных полей, то при последующем обновлении первичного ключа Access автоматически обновляет все связанные с ним поля.

Может понадобиться удалить строку и все связанные записи — например, запись грузоотправителя и все связанные с ним заказы. Для этого в Access имеется параметр Каскадное удаление связанных записей. Если при обеспечении целостности данных выбрать параметр Каскадное удаление связанных записей, а затем удалить запись на стороне первичного ключа в отношении, Access автоматически удалит все записи со ссылкой на первичный ключ.

Просмотр связей между таблицами

Чтобы просмотреть межтабличные связи, щелкните Схема данных на вкладке Работа с базами данных. Откроется окно «Схема данных», в котором будут отображены все существующие связи. Если связи еще не были определены или это окно открывается впервые, приложение Access предложит добавить в окно таблицу или запрос.

Вызов окна «Схема данных»

  1. Щелкните «Файл»,выберите«Открыть», а затем выберите и откройте базу данных.
  2. На вкладке Работа с базами данных в группе Отношения нажмите кнопку Схема данных.
  3. На вкладке Конструктор в группе Связи нажмите кнопку Все связи.

Связь между таблицами представляется как линия между таблицами в окне «Схема данных». Связь, не обеспечивающая целостность данных, отображается как тонкая линия между общими полями, поддерживающими связь. Если выбрать связь, щелкнув линию, то линия станет жирной. Если обеспечить целостность данных для этой связи, линия станет толще на концах. Кроме того, над жирной частью линии с одной стороны связи будет отображаться цифра 1, а с другой стороны — символ бесконечности ().

Когда открыто окно «Схема данных», на ленте доступны указанные ниже команды.

На вкладке Конструктор в группе Сервис

  • Изменить связи . Открывает диалоговое окно Изменение связей . При выборе линии связи можно щелкнуть элемент Изменить связи, чтобы изменить связь между таблицами. Можно также дважды щелкнуть линию связи.
  • Очистить макет . Запрещает отображение всех таблиц и связей в окне «Схема данных». Имейте в виду, что эта команда только скрывает таблицы и связи, но не удаляет их.
  • Отчет о связях . Создает отчет, отображающий таблицы и связи базы данных. В отчете отображаются только таблицы и связи, не скрытые в окне «Схема данных».

На вкладке Конструктор в группе Отношения

  • Добавление таблиц (добавление таблицы в Access 2013 Позволяет показывать в окне «Отношения» выбор таблиц.
  • Скрыть таблицу . Скрывает выбранную таблицу в окне «Схема данных».
  • Прямые связи . Отображает все связи и связанные таблицы для выбранной таблицы в окне «Схема данных», если они еще не отображены.
  • Все связи . Отображает все связи и связанные таблицы базы данных в окне «Схема данных». Имейте в виду, что скрытые таблицы (таблицы, для которых установлен флажок Скрытый в диалоговом окне Свойства) и их связи не будут отображены, если не установлен флажок «Показывать скрытые объекты» в диалоговом окне «Параметры переходов».
  • Закрыть . Закрывает окно «Схема данных». Если в макет окна «Схема данных» были внесены какие-либо изменения, будет предложено сохранить их.

Создание в БД связи один-ко-многим

Здраствуйте! Есть две таблицы один ко многим пытаюсь создать схему данных. Когда пытаюсь создать связь выдает ошибку. Можете, подсказать что я делаю не так?

94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
Ответы с готовыми решениями:

Создание связи один ко многим mysql workbench
Здравствуйте. Хочу создать связь один ко многим, соответственно для 2-х таблиц. Чтобы одной.

Определить тип связи между таблицами. Связь много-ко-многим или один-ко-многим?
Какой тип связи между таблица match и hero, match и team? Склоняюсь к варианту много-ко-многим.

Зачем нужны связи Один к Одному, Один ко Многим? Пример простой выборки
На этапе проектирования делаются связи один к одному один ко многим, откуда эти связи берутся.

Создание связи один ко многим MVVM
Приветствую! У меня сейчас вот такая модель WorkOrders Id, WorkOrder_CarModel и тд. Works.

8801 / 5706 / 578
Регистрация: 27.03.2013
Сообщений: 19,199

dima4239, первичный ключ, обычно имеет тип данных — Счётчик, ключевое.
Вторичный — Числовое, Длинное целое.
Прежде чем вводить данные, нужно сначала создать связь.
Так что сначала удалите из подчинённой таблицы все данные в поле связи и затем только уже можно будет вводить значения, но только те, что есть в первой таблице.
Вкратце, как то так.

Регистрация: 31.03.2013
Сообщений: 105

VinniPuh, у меня везде тип данных текстовой.

Добавлено через 52 секунды
VinniPuh, подробнее можно?

8801 / 5706 / 578
Регистрация: 27.03.2013
Сообщений: 19,199

Создавайте в обоих таблицах поля с типом данных — Счётчик и плюс ткните в значка — Ключик.
В таблице — Преподаватели , создайте поле с типом данных — Числовое и Длинное целое.
Ключевое от Код_ДисциплиныД, тяните к полю таблицы — КодДисциплиныП.
Ставьте галочку — Обеспечение целостности данных.

17368 / 7159 / 1616
Регистрация: 21.06.2012
Сообщений: 13,546

ЦитатаСообщение от dima4239 Посмотреть сообщение

Можете, подсказать что я делаю не так?

Все уже написано Вам в сообщении. В таблице подчиненной Вы ввели значения, которых нет в основной.
Сначала делают схему данных а потом уже вводят данные (чтобы ограничение внешнего ключа работало). Вы это правило нарушили. Теперь добавляйте в основную то, чего там нет, но есть в подчиненной. А уже потом делайте схему.

Регистрация: 31.03.2013
Сообщений: 105
Добавлено через 20 минут

ЦитатаСообщение от VinniPuh Посмотреть сообщение

Ключевое от Код_ДисциплиныД, тяните к полю таблицы — КодДисциплиныП
Два разных поля должны быть в таблице дисциплина?
8801 / 5706 / 578
Регистрация: 27.03.2013
Сообщений: 19,199
Это 2 разных поля, для связи в Разных таблицах.
Регистрация: 31.03.2013
Сообщений: 105

ЦитатаСообщение от dima4239 Посмотреть сообщение

Ключевое от Код_ДисциплиныД
какие значения туда вписать?
8801 / 5706 / 578
Регистрация: 27.03.2013
Сообщений: 19,199

dima4239, это счётчик, он сам автоматически вписывает сам в себя последовательные значения при создании новой записи.
Типа написали какое ни то значение в соседнем поле, например — Информатика, и в нем появилась циферка 1
Написали — Математика, появилась циферка 2
И так далее.
Сами вы в него ни чего внести не сможете.
И служит для связи с другими табличками и имеет Уникальное значение в данном поле, дабы не попереутать записи.
Если уж и сейчас что то не понятно, то я Бессилен объяснить более доходчиво.

Регистрация: 31.03.2013
Сообщений: 105
Получилось, спасибо. Как создать такую связь «Дисциплины» по полю «Дисциплина»?
Регистрация: 31.03.2013
Сообщений: 105
Уже не надо справился.
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
Помогаю со студенческими работами здесь

Организация связи один-ко многим
Стоит следующая задача: отобразить связь один ко многим в двух гридах. Для реализации я.

Вывод связи один ко многим
Здравствуйте, Имеется две таблицы со связью один ко многим. При нажатии на одну из строк в.

Правильная организация связи один ко многим
Здравствуйте, помогите разобратся с возникшей проблемой. Есть база данных (не моя) в ней две.

Код php для связи в базе access один ко многим
подскажите пожалуйста код php для связи в базе access один ко многим

Создание связи многие ко многим
Не могу понять, как правильно сделать. На данный момент только проектирую базу. Задание такое: .

Создание связи многие-ко-многим
Подскажите как правильно создать связь между таблицами бд "Many-to-Many" в Visual Studio? Как.

Связь таблиц в Access

Вся информация, которую можно получить из систем управления базами данных (СУБД), собрана в разных таблицах. Это необходимо для предотвращения переизбытка информации. Выборка и последующая работа с необходимыми сведениями осуществляется с помощью механизма связывания. Именно о том, как в Access связать таблицы и пойдет речь в этой статье. Связь происходит по общему полю, для которого следует задать определенный тип данных. Изменения можно вносить как в исходную, так и в связанную таблицу – они в любом случае будут отображаться в обеих БД.

Пошаговая инструкция

  1. Откройте БД в программе (помните, что связать можно минимум 2 таблицы в Access).
  2. Заполните поля информацией, учитывая, что для осуществления операции, поля должны иметь схожий тип данных. Если созданная связь имеет формат «один ко многим», то поля в первой таблице могут иметь тип «Счетчика», а соответствующая ячейка во второй – должна быть числовой. В качестве ключевого следует задать именно счетчик.
  3. Откройте меню «Сервис/Схема данных» после чего на экране появится область со связанными элементами. Если же она пуста, то окно добавления таблиц откроется в Access автоматически.
  4. Для того чтобы включить связываемые таблицы Access в открытую БД, следует выделять необходимые названия и кликать на кнопку «Добавить». При этом изображения с табличками будут появляться в рабочей области.
  5. Чтобы установить связи между таблицами в Access следует захватить поле одного объекта, перенести и отпустить мышку над соответствующим полем в другом. После этого на экране появится окошко с настройками.
  6. Если задать точное расположение ячеек в Access с помощью мышки не удалось, их можно настроить в выпадающих списках. Включение всех «флажков» обеспечит целостность и сохранность данных, а также их каскадное изменение.
  7. Установленный тип отношений можно просмотреть внизу окошка. Всего их три: «1 ко многим», «к одному» и «многие ко многим». Если в окне отобразился не тот параметр, значит, типы полей были заданы неверно.
  8. После нажатия на кнопку «Создать» между изображениями появится линия с цифрой 1 и символом бесконечности. Это значит, что объекты Access связаны соотношением «один ко многим».

Как видите, ничего сложного в установлении связи между таблицами в Access нет. Надеемся, что наше руководство окажется полезным для вас!

Ответы на другие вопросы:

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *