Files
project-replica/app/Models/Table.php
2026-03-23 00:51:38 +09:00

64 lines
1.4 KiB
PHP

<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\HasMany;
use Illuminate\Database\Eloquent\Relations\HasManyThrough;
class Table extends Model
{
use HasFactory;
protected $fillable = [
'source_database_id',
'schema_name',
'table_name',
'comment',
'options',
'last_checked_at',
];
protected $casts = [
'options' => 'array',
'last_checked_at' => 'datetime',
];
public function sourceDatabase(): BelongsTo
{
return $this->belongsTo(SourceDatabase::class);
}
public function columns(): HasMany
{
return $this->hasMany(Column::class);
}
public function indexes(): HasMany
{
return $this->hasMany(Index::class);
}
public function foreignKeys(): HasMany
{
return $this->hasMany(ForeignKey::class);
}
public function schemaChanges(): HasMany
{
return $this->hasMany(SchemaChange::class);
}
public function migrationScheduleTables(): HasMany
{
return $this->hasMany(MigrationScheduleTable::class);
}
public function getFullNameAttribute(): string
{
return "{$this->schema_name}.{$this->table_name}";
}
}