pongee / database-schema-visualization
Database schema visualization
Installs: 5 374
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/pongee/database-schema-visualization
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": []
}
