https://github.com/thinkphp6/thinkphp-migration-generator
thinkphp migration generator , ThinkPHP 数据库反向生成工具
https://github.com/thinkphp6/thinkphp-migration-generator
Last synced: 3 months ago
JSON representation
thinkphp migration generator , ThinkPHP 数据库反向生成工具
- Host: GitHub
- URL: https://github.com/thinkphp6/thinkphp-migration-generator
- Owner: thinkphp6
- License: gpl-3.0
- Created: 2021-07-31T01:16:14.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2021-12-02T07:03:04.000Z (over 4 years ago)
- Last Synced: 2025-11-06T14:18:05.480Z (5 months ago)
- Language: PHP
- Size: 43.9 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Migration Generator - Mysql数据表反向迁移文件生成
如果你还未使用或者正想使用数据库迁移功能,但又不并不想自己写迁移文件的话,这个工具可以很好的帮助实现文件迁移,
目前提供了 Laravel5.5+ 和 Thinkphp6+ 的迁移文件的生成。
源项目: https://github.com/JaguarJack/migration-generator
因为原本的存在一些BUG , Fork一个版本修复下
更新日志:
- [x] 修复DateTime大小写问题
- [x] 增加SimpleArrayType 修复Set类型导致异常问题
## 安装
```sh
composer require thinkphp6/thinkphp-migration-generator:dev-main
```
## 平台支持
#### laravel
```shell
php artisan migration:generate
```
#### ThinkPHP
```
php think migration:generate
```
#### 注意
> 包中提供的命令如果不能完全满足你的需求,那么你可以根据实际自定义需求。
### 定义新类型
- 继承 \Doctrine\DBAL\Types\Type
```php
class newType extend \Doctrine\DBAL\Types\Type{}
```
- 主要实现两个方法
```php
public function getSQLDeclaration(array $fieldDeclaration, AbstractPlatform $platform)
{
return $platform->getIntegerTypeDeclarationSQL($fieldDeclaration);
}
public function getName()
{
return 'TypeName';
}
```
- 注入
```php
$generator = new MigrateGenerator('thinkphp');
$generator->registerNewType([
'TypeName' => TypeClass
]);
```
### 新增类型解析
> 就是对应框架 migration 的格式
- 继承实现
```php
classType extend JaguarJack\MigrateGenerator\Migration\Columns\AbstractType
{}
```
> 继承这个基类可以获取两个信息
- 获取当前 `column` 的所有信息
- 整个表结构的原始信息 这里可以得到 `DBAL` 不会提供的信息
- 必须实现的两个方法
> 因为现在就支持了 laravel 和 thinkphp 所有就定义了这两个方法
```php
public function laravelMigrationColumn():string
public function thinkphpMigrationColumn():string
```
- 注入
```php
$generator = new MigrateGenerator('thinkphp');
$generator->registerNewTypeParse([
'TypeClassName' => ParseTypeClass
]);
```
> `TypeClassName` 指的就是新类型的类的名称
`ParseTypeClass` 也必须和 `TypeClass` 相同,这是约定,方便更好的解析。
### 其他
除了提供的自定义的命令外,通过两个对外接口自己生成文件
```php
$generator->getDatabase;
```
> 这个方法可以获取表信息以及字段信息等等
```php
$generator->getMigrationContent;
```
> 这个方法可以获取解析后 migration 文件内容