History:Object Model

This page has not been reviewed by our documentation team (more info).

Status: Image:Attention.png This page needs to be updated to reflect the results of the MusicBrainzSummit7

This page and its subpages form a document that tries to describe the reality that MusicBrainz deals with as abstract /Objects with Properties and /Relationships. This document is not about a database schema. Its purpose is to understand what we are dealing with. Of course, this effort is strongly related to the creation of a NextGenerationSchema.

This document is written in the form of CollectiveWe, and you are invited to BeBold and write things like "we seem to (dis)agree" or "we have forgotten an important aspect...". This should avoid lengthy threaded discussions.

Definitions

When talking about object definitions we need a well defined language. Here are the most important ones:

These were the most important. The rest is for later.

The Object Model

The actual object model currently consists of the following elements:

The following graphic describes the ObjectModel as refined on the summit (code-named "NadelnderBambus"). Note that the names have changed and might change again. Sorry for that:

Image:NadelnderBambus_0_1.png

See the attachments page for some older graphs.

Examples

Now that we have completed a first stab at the objects, we need to check whether they actually fit the reality. Big thanks to everybody who contributed to this list in the Next Generation Database Schema thread on the UsersMailingList.

  1. /FelaITTExample, showing an release that is a merge of two previously released releases, and a track that is a merge of two previously separated tracks.
  2. /GiantXmasExample, showing a Japanes one-time project as ReleaseArtist.
  3. /ShuujiAndAkiraExample, showing different ReleaseArtist and TrackArtists plus confusing aliases and PerformanceNames.
  4. /TerraRevolutionExample, showing one release with a single track being a megamix of another release.
  5. /PartyPeopleExample, showing an release containing one track being a megamix of all other tracks.
  6. /CassetteboyExample, showing an artist who changes his performance name for every track.
  7. /RunTimeAllStarsExample, showing varying and vague artist collaboration that had only this one release.
  8. /AhhcoExample, showing one track by another artist on a single artist release.
  9. /ElectricLightOrchestraExample, showing an release that has a different name in one country
  10. /AngeldustExample, showing two releases with exact same content, but released under different artist and title.
  11. /ChantsMagnetiquesExample , showing two localized variants onf one release.
  12. /DonSebskyExample, showing the case of a Jazz composer.
  13. TracksWithMultipleArtists contains an example of its own, showing tracks that consist of more than one song by more than one artist
  14. /QueenPlatinumCollectionExample, showing releases that were re-released as a box set without remastering.
  15. /GylleneTiderExample, showing releases that were re-released as a box set without remastering, and later as single remastered releases.
  16. /JesusChristSuperstarExample, which has tracks containing two songs and poses a challenge to the TrackGroup and AR.
  17. /DepecheModeRemixesExample, showing identical discs on different releases and other problems.