Это вопрос, который я задаю себе, когда сталкиваюсь с новыми проектами, Field Field vs Entity Reference + настраиваемый объект или, если структура проста, Field Collection vs настраиваемое поле с несколькими столбцами db / Multifield . Вот мое мнение, основанное на моем опыте .
Multifield - отличная концепция, это будет «облегченная» версия коллекции полей, вместо создания структуры сущностей со связями, она охватывает простые варианты использования без создания сущности. Однако у него есть ряд проблем , таких как неполная интеграция функций, не совсем многоязычность и т. Д. (Поэтому, если вы планируете использовать это, материалы, вероятно, будут действительно приветствоваться).
Field Collection - отличное решение, если вы создаете сайт, который можно сделать всего лишь несколькими хитростями, он дает разработчикам сайтов мощный инструмент для создания сложных структур, не беспокоясь о внутренних деталях. Он в основном создаст сущность, которая связана с сущностью «хост» идентификаторами, позволяя добавлять поля к ней и все остальное. Недостатки могут заключаться в знании внутренних элементов коллекции полей, необходимых для выполнения сложных операций, таких как управление коллекцией полей с использованием ссылки на сущность или перенос данных. Поскольку это универсальный инструмент, было бы довольно сложно сделать шаг вперед.
Еще один вариант, который у вас есть, это использование ECK с Entity Reference, но мой опыт с этим до сих пор был катастрофой, и я считаю, что проще создать тип сущности с помощью кода без помощника.
Это вопрос того, что вам нужно, и что лучше всего подходит для вашего проекта: если у вас есть время и разработчики для создания типов сущностей, которые связаны с вашей моделью данных через Entity Reference, вы будете иметь больше контроля над тем, что происходит с ваши структуры данных, но вы также «ответственны» за это.
После некоторого тестирования всех решений, описанных выше, в моей команде мы всегда выбираем типы сущностей + ER, но я вижу, что для небольших проектов, без миграции данных или сложной настройки i18n, Field Collection - это самый быстрый способ идти.