Skip to main content

MusicBrainz Database Tools

Project description

pypi badge

If you are developing a Python application that needs access to the MusicBrainz data, you can use the mbdata.models module to get SQLAlchemy models mapped to the MusicBrainz database tables.

All tables from the MusicBrainz database are mapped, all foreign keys have one-way relationships set up and some models, where it’s essential to access their related models, have two-way relationships (collections) set up.

In order to work with the relationships efficiently, you should use the appropriate kind of eager loading.

Example usage of the models:

>>> from sqlalchemy import create_engine
>>> from sqlalchemy.orm import sessionmaker
>>> from mbdata.models import Artist
>>> engine = create_engine('postgresql://musicbrainz:musicbrainz@127.0.0.1/musicbrainz', echo=True)
>>> Session = sessionmaker(bind=engine)
>>> session = Session()
>>> artist = session.query(Artist).filter_by(gid='8970d868-0723-483b-a75b-51088913d3d4').first()
>>> print artist.name

If you use the models in your own application and want to define foreign keys from your own models to the MusicBrainz schema, you will need to let mbdata know which metadata object to add the MusicBrainz tables to:

from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()

# this should be the first place where you import anything from mbdata
import mbdata.config
mbdata.config.configure(base_class=Base)

# now you can import and use the mbdata models
import mbdata.models

You can also use mbdata.config to re-map the MusicBrainz schema names, if your database doesn’t follow the original structure:

import mbdata.config
mbdata.config.configure(schema='my_own_mb_schema')

If you need sample MusicBrainz data for your tests, you can use mbdata.sample_data:

from mbdata.sample_data import create_sample_data
create_sample_data(session)

Development

Normally you should work against a regular PostgreSQL database with MusicBrainz data, but for testing purposes, you can use a SQLite database with small data sub-set used in unit tests. You can create the database using:

./bin/create_sample_db.py sample.db

Then you can change your configuration:

DATABASE_URI = 'sqlite:///sample.db'

Running tests:

pytest -v

If you want to see the SQL queries from a failed test, you can use the following:

MBDATA_DATABASE_ECHO=1 pytest -v

GitHub Actions workflow that automatically runs the tests after each commit is here.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mbdata-31.0.1.tar.gz (200.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mbdata-31.0.1-py3-none-any.whl (247.3 kB view details)

Uploaded Python 3

File details

Details for the file mbdata-31.0.1.tar.gz.

File metadata

  • Download URL: mbdata-31.0.1.tar.gz
  • Upload date:
  • Size: 200.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mbdata-31.0.1.tar.gz
Algorithm Hash digest
SHA256 859d2cacd70c7739c7444bc98cb6f57156e07c1c449b1bda56e8a74e515ba774
MD5 4b58451c970f36630a4ec553388f2aa9
BLAKE2b-256 36b1910cb8ec907580e3b77c9ae4ac3f4b4809d94a8e75f40746a4deef126dc3

See more details on using hashes here.

Provenance

The following attestation bundles were made for mbdata-31.0.1.tar.gz:

Publisher: publish.yml on metabrainz/mbdata

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mbdata-31.0.1-py3-none-any.whl.

File metadata

  • Download URL: mbdata-31.0.1-py3-none-any.whl
  • Upload date:
  • Size: 247.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mbdata-31.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 eda71b614e3d98fa26c8d81163730cc17e1e905f55a7bab1fa5fac961e8db4e7
MD5 c69b470ff365b3bfb8623bd8dce9b8be
BLAKE2b-256 582aba28902a0167ea520a41a2bbbfabc0dee011eea9ba58d9f967c6b0822095

See more details on using hashes here.

Provenance

The following attestation bundles were made for mbdata-31.0.1-py3-none-any.whl:

Publisher: publish.yml on metabrainz/mbdata

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page