可以创建command命令,使其打印出对应的注解:
<?php
namespace App\Console\Commands;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\DB;
class makeModel extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'make:model {--table=}';
/**
* The console command description.
*
* @var string
*/
protected $description = '创建model模型';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle()
{
$table = $this->option('table');
if (config('database.connections.mysql.prefix')) {
$table = config('database.connections.mysql.prefix').$table;
}
$sql = "select column_name,column_comment,data_type from information_schema.columns where table_name='".$table."' and table_schema='".env('DB_DATABASE')."' order by ORDINAL_POSITION asc";
$db = DB::select($sql);
if ($db && is_array($db)) {
foreach ($db as $key => $value) {
$type = 'string';
switch ($value->data_type) {
case 'bigint':case 'int':case 'tinyint':$type = 'int';break;
case 'decimal':$type = 'float';break;
case 'json': $type = 'array'; break;
}
echo '* @property '.$type.' '.$value->column_name.' '.$value->column_comment."\n";
}
}
}
}
即运行命令:php artisan make:model --table=XXX(table-name)