Skip to content

Latest commit

 

History

History
60 lines (47 loc) · 1.6 KB

README.md

File metadata and controls

60 lines (47 loc) · 1.6 KB

SQL Dependency Extraction Tool

This tool extracts dependencies between database objects:

  • views depend on tables or other views
  • tables may have foreign keys

At the moment, sqlgg can't parse all function calls and doesn't parse foreign keys at all, so I've thrown together a small but naïve shell script to analyze SQL scripts formatted the way I write them.

Usage

Manual

Extract dependencies, optionally prepending a schema name:

$ ./sqldep print <demo/print/schema.sql |tee demo/print.dep
TABLE print.paper:
TABLE print.service: print.paper
VIEW print.per_user: print.service print.paper
VIEW print.per_class: print.service print.paper school.class

Extract dependencies from another SQL script:

$ ./sqldep school <demo/school/schema.sql >demo/school.dep

Concatenate dependency information:

$ cat demo/{print,school}.dep >demo/all.dep

Convert dependencies to a dot script, then render it using GraphViz:

$ utils/sqldep_to_dot <demo/all.dep |dot -Tsvg >demo/objects.svg

Object Dependencies

Convert dependencies to a dot script describing inter-schema dependencies, then render it using GraphViz:

$ (cd utils; ./sqldep_to_schema_dot) <demo/all.dep |dot -Tsvg >demo/schemata.svg

Schema Dependencies

Semi-automatic

$ cd demo/data
$ make

Fully automatic

Checks can be run before each commit using a pre-commit hook. Please install hooks/pre-commit into each of your repositories' .git/hooks.