easyswoole / hyperf-orm
easyswoole hyperf orm
dev-master
2021-06-21 15:14 UTC
Requires
- php: >=7.2
- doctrine/dbal: 2.10.4
- easyswoole/command: ^1.1
- easyswoole/component: ^2.2
- easyswoole/pool: ^1.0
- hyperf/database: ^2.0
Requires (Dev)
- easyswoole/swoole-ide-helper: ^1.2
- nikic/php-parser: ^4.4
This package is auto-updated.
Last update: 2024-12-21 23:08:51 UTC
README
EasySwoole Hyperf Orm
Install
The preferred way to install this extension is through composer.
Either run
composer require easyswoole/hyperf-orm
or add
"easyswoole/hyperf-orm": "*"
to the require section of your composer.json
file.
Config
dev.php or product.php
<?php return [ 'databases' => [ 'default' => [ 'driver' => 'mysql', 'host' => '127.0.0.1', 'port' => 3306, 'database' => 'easysoole', 'username' => 'root', 'password' => '', 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => 't_', 'showSql' => false, 'pool' => [ 'intervalCheckTime' => 15 * 1000, 'maxIdleTime' => 60, 'maxObjectNum' => 15, 'minObjectNum' => 1, 'getObjectTimeout' => 3.0, ], 'commands' => [ 'gen:model' => [ 'path' => 'App/Model', 'force_casts' => true, 'inheritance' => 'Model', 'uses' => 'EasySwoole\HyperfOrm\Model', 'refresh_fillable' => true, 'with_comments' => true, ], ], 'options' => [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_STRINGIFY_FETCHES => false, ], ], ] ];
Use
EasySwooleEvent.php
<?php use Psr\Container\ContainerInterface; use EasySwoole\HyperfOrm\Container; use EasySwoole\HyperfOrm\ConfigFactory; use EasySwoole\HyperfOrm\ConnectionResolver; use Hyperf\Contract\ConfigInterface; use Hyperf\Database\ConnectionResolverInterface; use EasySwoole\Component\Di; use EasySwoole\EasySwoole\Config; use EasySwoole\Pool\Manager; use EasySwoole\HyperfOrm\MysqlPool; use Hyperf\Utils\ApplicationContext; public static function initialize() { Di::getInstance()->set(ContainerInterface::class, Container::class); ApplicationContext::setContainer(Di::getInstance()->get(ContainerInterface::class)); Di::getInstance()->set(ConfigInterface::class, ConfigFactory::class); Di::getInstance()->set(ConnectionResolverInterface::class, ConnectionResolver::class); $databases = Config::getInstance()->getConf('databases'); $manager = Manager::getInstance(); foreach ($databases as $name => $conf) { if (!is_null($manager->get($name))) { continue; } Manager::getInstance()->register(new MysqlPool($conf), $name); } }
Command Config
bootstrap.php
<?php //全局bootstrap事件 use EasySwoole\HyperfOrm\CommandUtility; // command CommandUtility::getInstance()->init();
Command
// model
php easyswoole gen:model
or
php easyswoole gen:model tableName
// migrate
php easyswoole gen:model
php easyswoole migrate
php easyswoole migrate:fresh
php easyswoole migrate:install
php easyswoole migrate:refresh
php easyswoole migrate:reset
php easyswoole migrate:rollback
php easyswoole migrate:status
Model
<?php declare (strict_types=1); namespace App\Model; use EasySwoole\HyperfOrm\Model; /** * @property string $demo_id * @property int $create_at * @property int $update_at */ class Demo extends Model { /** * primaryKey * * @var string */ protected $primaryKey = 'demo_id '; /** * The table associated with the model. * * @var string */ protected $table = 'demo'; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = ['demo_id', 'create_at', 'update_at']; /** * The attributes that should be cast to native types. * * @var array */ protected $casts = ['demo_id' => 'string', 'create_at' => 'datetime', 'update_at' => 'datetime']; }