I have an application where an article can be linked to multiple platforms.
Article contains a list of platforms and platforms also contains a list of articles.
For more detailed information please look at this stackoverflow question that I asked a few months ago.
https://stackoverflow.com/a/40377383/5770147
The question was on how to create an article and implement the N-N relationship between article and platform.
I have Creating article and Deleting the article setup so that the lists update in the platforms aswell.
How do I implement editing an article so I can update which platforms are linked to an article?
For creating and editing the linked platforms I use a dropdown menu in which multiple options can be selected. The necessary code can be found in the question previously linked.
Based on the information that you provided, I would recommend two possible approaches, starting from the same foundation:
I would recommend this approach if:
You want to be able to manage both entities independently, while also syncing references between them
Even if this approach is quite flexible, it comes at a cost - if you require both article and platform data, you will have to fire more queries to your MongoDB instance, as the data is split in two different collections.
For example, when loading an article page, considering that you also want to display a list of
platforms
, you would have to fire a query to thearticles collection
, and then also trigger a search on theplatforms collection
to retrieve all the platform entities to which that article is published via the members of theplatform
s array on thearticle document
.However, if you only have a small subset of frequently accessed
platform attributes
that you need to have available when loading anarticle document
, you might enhance theplatforms
array on thearticles collection
to store those attributes in addition to the_id
reference to the platform documents:}
This hybrid approach would be suitable if the
platform data attributes
that you frequently retrieve to display together with article specific data are not changing that often.Otherwise, you will have to synchronize all the updates that are made to the
platform document attributes
in theplatforms collection
with the subset of attributes that you track as part of the platforms array for article documents.Regarding the management of article lists for individual platforms, I wouldn't recommend storing N-to-N references in both collections, as the aforementioned mechanism already allows you to extract article lists by querying the
articles collection
using a find query with the_id
value of theplatform document
:Having presented two different approaches, what I would recommend now is for you to analyze the query patterns and performance thresholds of your application and make a calculated decision based on the scenarios that you encounter.