czproject / sql-generator
SQL 生成器。
v2.2.0
2023-07-27 07:30 UTC
Requires
- php: >=5.6.0
Requires (Dev)
- nette/tester: ^2.0
README
安装
composer require czproject/sql-generator
CzProject\SqlGenerator
需要 PHP 5.6.0 或更高版本。
用法
use CzProject\SqlGenerator\Drivers; use CzProject\SqlGenerator\SqlDocument; $sql = new SqlDocument; $driver = new Drivers\MysqlDriver; $contactTable = $sql->createTable('contact') ->setComment('Clients table.') ->setOption('ENGINE', 'InnoDB'); $contactTable->addColumn('id', 'INT', NULL, array('UNSIGNED' => NULL)) ->setAutoIncrement(); $contactTable->addColumn('name', 'VARCHAR(100)') ->setComment('Client name'); $contactTable->addColumn('surname', 'VARCHAR(100)'); $contactTable->addColumn('active', 'unsigned TINYINT') ->setDefaultValue(TRUE); $contactTable->addColumn('created', 'DATETIME'); $contactTable->addColumn('removed', 'DATETIME') ->setNullable(); $contactTable->addIndex(NULL, IndexDefinition::TYPE_PRIMARY) ->addColumn('id'); $contactTable->addIndex('name_surname', IndexDefinition::TYPE_UNIQUE) ->addColumn('name', 'ASC', 100) ->addColumn('surname', 'DESC', 100); $output = $sql->toSql($driver);
输出
CREATE TABLE `contact` ( `id` INT UNSIGNED NOT NULL AUTO_INCREMENT, `name` VARCHAR(100) NOT NULL COMMENT 'Client name', `surname` VARCHAR(100) NOT NULL, `active` TINYINT(1) UNSIGNED NOT NULL DEFAULT 1, `created` DATETIME NOT NULL, `removed` DATETIME NULL, PRIMARY KEY (`id`), UNIQUE KEY `name_surname` (`name` (100), `surname` (100) DESC) ) COMMENT 'Clients table.' ENGINE=InnoDB;
语句
有少量预定义语句
$sql->createTable($tableName); $sql->dropTable($tableName); $sql->renameTable($old, $new); $sql->alterTable($tableName); $sql->insert($tableName, $data); $sql->command($command); // for example $sql->command('SET NAMES "utf8"'); $sql->comment($comment);
可以添加自定义语句
$sql->addStatement(new Statements\CreateTable($tableName));
检查 SQL 文档是否为空
$sql->isEmpty();
生成 SQL
$sql->toSql($driver); // returns string $sql->getSqlQueries($driver); // returns string[] $sql->save($file, $driver); // saves SQL into file
特殊值
针对特定情况存在值对象
TableName
分隔的表名。
use CzProject\SqlGenerator\TableName; $table = $sql->createTable(TableName::create('schema.table')) $table->addForeignKey('fk_table_id', 'id', TableName::create('schema2.table2'), 'id'); // and more ($sql->renameTable(),...)
Value
标量/可转换为字符串的/日期时间值。它可以用作选项值。
use CzProject\SqlGenerator\Value; $table->setOption('AUTO_INCREMENT', Value::create(123)); // generates AUTO_INCREMENT=123 $table->setOption('CHECKSUM', Value::create(FALSE)); // generates CHECKSUM=0 $table->setOption('COMPRESSION', Value::create('NONE')); // generates COMPRESSION='NONE'
支持数据库
目前支持常见的 SQL 和 MySQL。
许可协议: 新 BSD 许可协议
作者:Jan Pecha,https://www.janpecha.cz/