Skip to main content

Python package installation for ipython_magic_sqlalchemy_schemadisplay

Project description

ipython_magic_sqlalchemy_schemadisplay

Magic for sqlalchemy_schemadisplay

Binder

Magic originally created for the Open University module TM351 Data Management and Analysis. This magic complements the ipython-sql, which provides magics for connecting to a SQL database, with a magic that uses sqlalchemy_schemadisplay to generate ERDs over a SQL database. The code for generating the ER diagram can be found in the third party sqlalchemy_schemadisplay package.

At the moment, the schema display and ipython-sql magics and independent, but they really should be combined into a single package.

Usage

Install from PyPi: pip install schemadisplay-magic

Install from this repo:

pip install git+https://github.com/innovationOUtside/ipython_magic_sqlalchemy_schemadisplay.git

Note there are several other dependencies:

  • Python: see requirements.txt
  • O/S: see apt.txt

Install either ipython-sql or jupysql to access the $%sql magic:

  • either ipython-sql, or
  • pip install jupysql

Set up a database. For example, load the SQL magic:

%load_ext sql

Create a database connection string — we can use a SQLite database for demo purposes — and connect the SQL magic to the database:

# With ipython-sql:
DB_CONNECTION = 'sqlite:///./test.db'
%sql $DB_CONNECTION

# With jupysql:
from sqlalchemy import create_engine
engine = create_engine(DB_CONNECTION)
%sql engine

Populate the database with a couple of foreign key related tables:

%%sql

DROP TABLE IF EXISTS doctor;

CREATE TABLE doctor (
    
    doctor_id CHAR(4),
    doctor_name VARCHAR(20),
    
    PRIMARY KEY (doctor_id)
 );

DROP TABLE IF EXISTS patient;

CREATE TABLE patient (
    
    patient_id CHAR(4),
    patient_name VARCHAR(20),
    date_of_birth DATE,
    gender CHAR(6),
    height_cm DECIMAL(4,1),
    weight_kg DECIMAL(4,1),
    doctor_id CHAR(4),
    
    PRIMARY KEY (patient_id),
    
    FOREIGN KEY (doctor_id) REFERENCES doctor
 );
 

Load the schema display magic, and render the schema from the connected database:

%load_ext schemadisplay_magic
%schema --connection_string $DB_CONNECTION

Alternatively, use a jupysql connections file (~/.jupysql/connections.ini): %schema --connection_string $DB_CONNECTION

At the moment, the database connection string needs to be provided to the schem magic for each diagram. [TO DO - fix this to use a single persistemt connection for the life of the notebook session, once connected.]

Using the Magic in a Teaching and Learning Context

The magic was developed to support teaching and learning around the topic of relational databases. Students were working with a PostgreSQL database, creating, editing and deleting tables, and creating foreign key relationships between tables. The magic provided an easy way to visualise the current state of the tables available in the database, and any foreign key relationships between them.

In this way, students could run database and table modifying statements in a notebook. A single line magic invocation could then be used to generate a visual representation of the current state of the database to check that their intended changes had worked correctly.

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

schemadisplay-magic-0.0.8.tar.gz (9.5 kB view details)

Uploaded Source

Built Distribution

schemadisplay_magic-0.0.8-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file schemadisplay-magic-0.0.8.tar.gz.

File metadata

  • Download URL: schemadisplay-magic-0.0.8.tar.gz
  • Upload date:
  • Size: 9.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for schemadisplay-magic-0.0.8.tar.gz
Algorithm Hash digest
SHA256 d99c710a79a26bf1da84362c431af9e35d1c3346bf6ccb2b63d19cbb370ab467
MD5 3c7d4196870836e5676005f600f89fa0
BLAKE2b-256 3625ddb8bd7e65d9933875c93814239e0faed87b19fbc385e7632fbefef75346

See more details on using hashes here.

File details

Details for the file schemadisplay_magic-0.0.8-py3-none-any.whl.

File metadata

File hashes

Hashes for schemadisplay_magic-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 030d8ae26e82e76020ebd6d27d870075c52df3377f83b3a1a4463335dfd439ca
MD5 475877b5cfe1c8ebdb3ac30fa9a2b944
BLAKE2b-256 6d33761f8893c7d36abc02623694d07c488a28b2cb80d7a3ffd507f39338f004

See more details on using hashes here.

Supported by

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