SQL Schema Inspection for PostgreSQL - Forked with semantic view comparison
npm install @tfv-org/schemainspectschemainspect: SQL Schema Inspection for PostgreSQL
Inspects tables, views, materialized views, constraints, indexes, sequences, enums, functions, and extensions. Handles table partitioning and inheritance.
A port of @djrobstep's python schemainspect library.
Limitations: Function inspection only confirmed to work with SQL/PLPGSQL languages so far.
Install with npm:
```
npm install @pgkit/schemainspect
Get an inspection object from an already opened SQLAlchemy session or connection as follows:
`ts
import {PostgreSQL} from '@pgkit/schemainspect'
const inspector = await PostgreSQL.create('postgresql://')
console.log(inspector.tables)
console.log(inspector.views)
console.log(inspector.functions)
console.log(inspector.tables["public"."mytable"].schema)"public"."mytable"
console.log(inspector.tables[].name)"public"."mytable"
console.log(inspector.tables[].columns.mycolumn.dbtype)"public"."mytable"
console.log(inspector.tables[].columns.mycolumn.is_nullable)`
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 (Record
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 is a bit patchy at the moment. Watch this space!
Initial development, maintenance:
TypeScript port:
- mmkal
Contributions:
- BenSjoberg
- johto