Skip to main content

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. Handles table partitioning and inheritance.

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

schemainspect-0.1.1601964119.tar.gz (25.7 kB view details)

Uploaded Source

Built Distribution

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

schemainspect-0.1.1601964119-py2.py3-none-any.whl (34.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file schemainspect-0.1.1601964119.tar.gz.

File metadata

  • Download URL: schemainspect-0.1.1601964119.tar.gz
  • Upload date:
  • Size: 25.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.5 CPython/3.8.2 Linux/4.15.0-1077-aws

File hashes

Hashes for schemainspect-0.1.1601964119.tar.gz
Algorithm Hash digest
SHA256 1cbcd7cb0d01cccbf771c5c2fb1d84aa7f41e23df795a62c061276a77f95b41e
MD5 5a7fba499b24f3d8a881f48035707fb5
BLAKE2b-256 b346a4257c9359a1fb15c869a3ebf834364d8c7943aa1a4bd57e97387f43b97b

See more details on using hashes here.

File details

Details for the file schemainspect-0.1.1601964119-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for schemainspect-0.1.1601964119-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 f8f10e253095571e6cd49ee1996e205b775ea2c7fb3d36778d3ae494b402f1a0
MD5 49fecff169326190e337d2bc1b4f07d8
BLAKE2b-256 836ac714d5ab5b4c11a9a0bf48c20fe6ef5b1de0ae44a1c79c39b690ba54cceb

See more details on using hashes here.

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