Skip to main content

Compute functional dependencies for database schema design and normalization: implication, closure, synthesis

Project description

REUSE status Binder

Overview

This package provides an Open Educational Resource (OER) to refresh prior knowledge about functional dependencies (FDs) and normalization of relational database schemata. Towards that goal, the package implements algorithms for the manipulation of functional dependencies; the package’s doc string explains the used vocabulary and contains examples.

Selected algorithms:

  • FD.rminimize(): Return a minimal cover of r-minimal FDs
  • FDSet.closure(): Return closure of attributes under given FDs
  • FDSet.lminimize(): Return minimum subset of lhs that determines rhs
  • FDSet.key(): Return a key
  • FDSet.basis(): Return non-redundant r- and l-minimal basis/cover
  • RelSchema.synthesize(): Normalize via synthesis into set of 3NF schemata

Installation and usage

This is Python software.

A 3NF synthesis example is available as notebook on mybinder.org; you can use that notebook in your web browser (without the need to install further software).

To normalize your own schemata, you may prefer to use the software locally. You can either clone the source repository (git clone https://gitlab.com/oer/cs/functional-dependencies.git) or install the PyPI package (pip install functional-dependencies).

The docstring for module functional_dependencies provides an introduction and several examples. See here for generated documentation.

Comments, feedback, improvements

Your feedback is highly appreciated. Feel free to open issues or merge requests in the source repository. For merge requests, make sure that pre-commit hooks are installed and run successfully as indicated next.

Side goal

Besides, the package may serve as sample Python code that respects usual coding conventions, which are checked with pre-commit hooks. The configuration file .pre-commit-config.yaml specifies test tools used here.

Origin of code

The code here is based on that file, which will not be maintained any longer.

Changelog

Changelog information is based on Keep a Changelog, where version numbers adhere to Semantic Versioning.

[Unreleased]

[1.3.0] - 2022-06-06

Added

  • Optional parameter attributes in FDSet.key()

Fixed

  • Previously, attributes of a relation schema were largely ignored, potentially leading to incorrect keys and synthesis results. Make sure in RelSchema.synthesize() that also attributes that do not occur in any FD are implied by the key (see doctest with nokeyschema).

[1.2.1] - 2021-01-05

Fixed

  • Remove cyclic module import for doctest

[1.2.0] - 2020-12-30

Added

  • Gitlab CI/CD

Changed

  • Use project_urls in setup.py

[1.1.0] - 2020-12-28

Added

  • Parameter minimize in RelSchema.synthesize().
  • Sample notebook with 3NF example by Codd, also at mybinder.org.

Fixed

  • Import in init.py.
  • Project URL in docstring.
  • Raw URL for coverage badge in setup.py.
  • URL for REUSE badge in README.md.

[1.0.1] - 2020-12-22

Fixed

  • Package URL and coverage badge in setup.py.

[1.0.0] - 2020-12-22

No change in functionality.

[1.0.0-rc.1] - 2020-12-22

Initial release. Code from there packaged for independent distribution.

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

functional_dependencies-1.3.0.tar.gz (34.3 kB view details)

Uploaded Source

Built Distribution

functional_dependencies-1.3.0-py2.py3-none-any.whl (33.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file functional_dependencies-1.3.0.tar.gz.

File metadata

  • Download URL: functional_dependencies-1.3.0.tar.gz
  • Upload date:
  • Size: 34.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.8.1

File hashes

Hashes for functional_dependencies-1.3.0.tar.gz
Algorithm Hash digest
SHA256 75dd71b8a912796f2092b3f1e2e9f0e987fd92c890622005f5515c95d604750e
MD5 848ca2f469b5f71b6154a650f40ea93e
BLAKE2b-256 56c87f69f31c8bbac81314597867a68ff74f4062dcc121b45e1370803d70aed7

See more details on using hashes here.

File details

Details for the file functional_dependencies-1.3.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for functional_dependencies-1.3.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 da83141ffd8860fe69ca9a75c67fd3c616bf2b1385b9110a64d1b478559ed332
MD5 82c0d6fb2ca069d844878686a34a1155
BLAKE2b-256 564f5e908eee709e9f0f73125fae92105958e7e8e2b2306efa1d5ff2b60efc99

See more details on using hashes here.

Supported by

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