MyGit

auraphp/Aura.SqlSchema

Fork: 14 Star: 41 (更新于 2024-09-06 17:26:58)

license: BSD-2-Clause

Language: PHP .

Independent schema discovery tools for MySQL, PostgreSQL, SQLite, and Microsoft SQL Server.

最后发布版本: 2.0.3 ( 2016-04-29 21:48:57)

GitHub网址

Aura.SqlSchema

Provides facilities to read table names and table columns from a database using a PDO connection.

Foreword

Installation

This library requires PHP 5.3 or later; we recommend using the latest available version of PHP as a matter of principle. It has no userland dependencies.

It is installable and autoloadable via Composer as aura/sqlschema.

Alternatively, download a release or clone this repository, then require or include its autoload.php file.

Quality

Scrutinizer Code Quality Code Coverage Build Status

To run the unit tests at the command line, issue phpunit at the package root. (This requires PHPUnit to be available as phpunit.)

This library attempts to comply with PSR-1, PSR-2, and PSR-4. If you notice compliance oversights, please send a patch via pull request.

Community

To ask questions, provide feedback, or otherwise communicate with the Aura community, please join our Google Group, follow @auraphp on Twitter, or chat with us on #auraphp on Freenode.

Getting Started

Instantiation

Instantiate a driver-specific schema object with a matching PDO instance:

<?php
use Aura\SqlSchema\ColumnFactory;
use Aura\SqlSchema\MysqlSchema; // for MySQL
use Aura\SqlSchema\PgsqlSchema; // for PostgreSQL
use Aura\SqlSchema\SqliteSchema; // for Sqlite
use Aura\SqlSchema\SqlsrvSchema; // for Microsoft SQL Server
use PDO;

// a PDO connection
$pdo = new PDO(...);

// a column definition factory
$column_factory = new ColumnFactory();

// the schema discovery object
$schema = new MysqlSchema($pdo, $column_factory);
?>

Fetching Table Lists

To get a list of tables in the database, issue fetchTableList():

<?php
$tables = $schema->fetchTableList();
foreach ($tables as $table) {
    echo $table . PHP_EOL;
}
?>

Fetching Column Information

To get information about the columns in a table, issue fetchTableCols():

<?php
$cols = $schema->fetchTableCols('table_name');
foreach ($cols as $name => $col) {
    echo "Column $name is of type "
       . $col->type
       . " with a size of "
       . $col->size
       . PHP_EOL;
}
?>

Each column description is a Column object with the following properties:

  • name: (string) The column name

  • type: (string) The column data type. Data types are as reported by the database.

  • size: (int) The column size.

  • scale: (int) The number of decimal places for the column, if any.

  • notnull: (bool) Is the column marked as NOT NULL?

  • default: (mixed) The default value for the column. Note that sometimes this will be null if the underlying database is going to set a timestamp automatically.

  • autoinc: (bool) Is the column auto-incremented?

  • primary: (bool) Is the column part of the primary key?

最近版本更新:(数据更新于 2024-09-07 05:36:57)

2016-04-29 21:48:57 2.0.3

2016-02-10 05:33:49 2.0.2

2015-03-28 05:02:16 2.0.1

2015-03-17 05:56:44 2.0.0

2014-01-10 23:27:23 2.0.0-beta1

主题(topics):

aura, database, pdo, php, sql

auraphp/Aura.SqlSchema同语言 PHP最近更新仓库

2024-09-18 20:45:32 coollabsio/coolify

2024-09-17 03:04:08 caseyamcl/guzzle_retry_middleware

2024-09-16 23:17:15 cakephp/migrations

2024-09-14 10:53:46 cakephp/cakephp

2024-09-06 16:28:08 spatie/holidays

2024-09-06 02:33:26 CakeDC/users