mirror of
				https://github.com/dg/dibi.git
				synced 2025-10-21 17:58:02 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| declare(strict_types=1);
 | |
| ?>
 | |
| <!DOCTYPE html><link rel="stylesheet" href="data/style.css">
 | |
| 
 | |
| <h1>Database Reflection | Dibi</h1>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| if (@!include __DIR__ . '/../vendor/autoload.php') {
 | |
| 	die('Install packages using `composer install`');
 | |
| }
 | |
| 
 | |
| 
 | |
| $dibi = new Dibi\Connection([
 | |
| 	'driver' => 'sqlite',
 | |
| 	'database' => 'data/sample.s3db',
 | |
| ]);
 | |
| 
 | |
| 
 | |
| // retrieve database reflection
 | |
| $database = $dibi->getDatabaseInfo();
 | |
| 
 | |
| echo "<h2>Database '{$database->getName()}'</h2>\n";
 | |
| echo "<ul>\n";
 | |
| foreach ($database->getTables() as $table) {
 | |
| 	echo '<li>', ($table->isView() ? 'view' : 'table') . " {$table->getName()}</li>\n";
 | |
| }
 | |
| echo "</ul>\n";
 | |
| 
 | |
| 
 | |
| // table reflection
 | |
| $table = $database->getTable('products');
 | |
| 
 | |
| echo "<h2>Table '{$table->getName()}'</h2>\n";
 | |
| 
 | |
| echo "Columns\n";
 | |
| echo "<ul>\n";
 | |
| foreach ($table->getColumns() as $column) {
 | |
| 	echo "<li>{$column->getName()} <i>{$column->getNativeType()}</i> <code>{$column->getDefault()}</code></li>\n";
 | |
| }
 | |
| echo "</ul>\n";
 | |
| 
 | |
| 
 | |
| echo 'Indexes';
 | |
| echo "<ul>\n";
 | |
| foreach ($table->getIndexes() as $index) {
 | |
| 	echo "<li>{$index->getName()} " . ($index->isPrimary() ? 'primary ' : '') . ($index->isUnique() ? 'unique' : '') . ' (';
 | |
| 	foreach ($index->getColumns() as $column) {
 | |
| 		echo $column->getName(), ', ';
 | |
| 	}
 | |
| 	echo ")</li>\n";
 | |
| }
 | |
| echo "</ul>\n";
 |