pongee / database-schema-visualization
Database schema visualization
Installs: 4 297
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 1
Forks: 1
Open Issues: 0
Requires
- php: >=8.1
- ext-json: *
- symfony/console: ^5.0||^6.0
- twig/twig: ^3.0
Requires (Dev)
- phpstan/phpstan: ^2.0
- phpunit/phpunit: ^10.0
- rector/rector: ^2.0
- roave/security-advisories: dev-latest
- slevomat/coding-standard: ^8.0
- squizlabs/php_codesniffer: ^3.0
README
Project goal
The aim of this project is to generate database documentation from sql schema.
Supported databases
- MySQL
- MariaDB
- Apache Cassandra (Basics)
Supported Output formats
- PNG, SVG image
- Plantuml raw text
- Json
Pre Installation
Installation
$ composer require pongee/database-schema-visualization or add it the your composer.json and make a composer update pongee/database-schema-visualization.
Usage
In console
PNG export
$ php ./database-schema-visualization mysql:image ./example/schema/sakila.sql > ./example/img/sakila.png $ php ./database-schema-visualization mysql:image --type png ./example/schema/sakila.sql > ./example/img/sakila.png
SVG export
$ php ./database-schema-visualization mysql:image --type svg ./example/schema/sakila.sql > ./example/img/sakila.svg
Json export
$ php ./database-schema-visualization mysql:json ./example/schema/sakila.sql
Plantuml export
$ php ./database-schema-visualization mysql:plantuml ./example/schema/sakila.sql
PHP
Png export
<?php declare(strict_types=1); use Pongee\DatabaseSchemaVisualization\DataObject\Sql\Database\Connection\ConnectionCollection; use Pongee\DatabaseSchemaVisualization\Export\Plantuml; use Pongee\DatabaseSchemaVisualization\Generator\ImageGenerator; use Pongee\DatabaseSchemaVisualization\Parser\MysqlParser; include __DIR__ . '/../../vendor/autoload.php'; $sqlSchema = ' CREATE TABLE IF NOT EXISTS `foo` ( `id` INT(10) UNSIGNED NOT NULL COMMENT "The id" ) ENGINE=innodb DEFAULT CHARSET=utf8; '; $sqlParser = new MysqlParser(); // $cqlParser = new \Pongee\DatabaseSchemaVisualization\Parser\CassandraParser(); $plantumlExport = new Plantuml(file_get_contents(__DIR__ . '/../../src/Template/Plantuml/v1.twig')); $forcedConnectionCollection = new ConnectionCollection(); $imageGenerator = new ImageGenerator( 'png', __DIR__ . '/../../bin/plantuml.jar', __DIR__ . '/../../tmp/' ); $schema = $sqlParser->run($sqlSchema, $forcedConnectionCollection); print $imageGenerator->generate($plantumlExport->export($schema));
Json export
<?php declare(strict_types=1); use Pongee\DatabaseSchemaVisualization\DataObject\Sql\Database\Connection\ConnectionCollection; use Pongee\DatabaseSchemaVisualization\Export\Json; use Pongee\DatabaseSchemaVisualization\Parser\MysqlParser; include './vendor/autoload.php'; $sqlSchema = ' CREATE TABLE IF NOT EXISTS `foo` ( `id` INT(10) UNSIGNED NOT NULL COMMENT "The id" ) ENGINE=innodb DEFAULT CHARSET=utf8; '; $mysqlParser = new MysqlParser(); $jsonExport = new Json(); $forcedConnectionCollection = new ConnectionCollection(); $schema = $mysqlParser->run($sqlSchema, $forcedConnectionCollection); print $jsonExport->export($schema);
This will generate:
{ "tables": { "foo": { "columns": [ { "name": "id", "type": "INT", "typeParameters": [ "10" ], "otherParameters": "UNSIGNED NOT NULL", "comment": "The id" } ], "indexs": { "simple": [], "spatial": [], "fulltext": [], "unique": [] }, "primaryKey": [] } }, "connections": [] }