Schema inspection for PostgreSQL (and possibly others)
Project description
schemainspect
: SQL Schema Inspection
Schema inspection for PostgreSQL (and potentially others in the future).
Inspects tables, views, materialized views, constraints, indexes, sequences, enums, functions, and extensions.
Limitations: Function inspection only confirmed to work with SQL/PLPGSQL languages so far.
Basic Usage
Get an inspection object from an already opened SQLAlchemy session or connection as follows:
from schemainspect import get_inspector
from sqlbag import S
with S('postgresql:///example') as s:
i = get_inspector(s)
The inspection object has attributes for tables, views, and all the other things it tracks. At each of these attributes you'll find a dictionary (OrderedDict) mapping from fully-qualified-and-quoted-name-of-thing-in-database to information object.
For instance, the information about a table books would be accessed as follows:
>>> books_table = i.tables['"public"."books"']
>>> books_table.name
'books'
>>> books_table.schema
'public'
>>> [each.name for each in books_table.columns]
['id', 'title', 'isbn']
Documentation
Documentation is a bit patchy at the moment. Watch this space!
Author Credits
Initial development, maintenance:
Contributions:
Install
Install with pip:
$ pip install schemainspect
To install psycopg2 (the PostgreSQL driver) at the same time as well:
$ pip install schemainspect[pg]
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for schemainspect-0.1.1552220105.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 631838e61965ead258edac6c010a36745159f3a0ab7f36c9cbc8e2c0c8ba546b |
|
MD5 | d7722ebab5b95d1f369eeaa5c97531ac |
|
BLAKE2b-256 | ee637ef464ca7f996854b7f6ee7c893eabbfeb01d16d52e161a3d9cadb8a5db8 |
Hashes for schemainspect-0.1.1552220105-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ce0e7760512382456d45f42356126e75d45a84c6b32a0e7bb0cc7edaf1cfa0c0 |
|
MD5 | 80fe63138449692d8e57cce225c741a1 |
|
BLAKE2b-256 | 085869038bc03fd3a161db3dbd20d89b7f7ac0aa7f3ce8d61a9adfe717c3e0d0 |