在 Laravel 6 中,设置与获取同一个模型的自关联
1、表存在 2 个字段:original_theme_id、theme_id,字段 original_theme_id 的值源自于表中的另一条记录的 theme_id。如图12、在模型中设置一对一的反向关联。代码实现如下3、获取关联属性的代码实现,生成的 SQL4、打印结果,符合预期
/**
* 获取此主题安装所属原始的主题安装
* @return BelongsTo
*/
public function originalThemeInstallation()
{
return $this->belongsTo('Modules\ThemeStoreDB\Entities\ThemeInstallation', 'original_theme_id', 'theme_id');
}
$themeInstallation = ThemeInstallation::find(345);
print_r($themeInstallation->originalThemeInstallation);
exit;
select
*
from
`theme_installation`
where
`theme_installation`.`theme_id` = '96b1c8b9-5b18-4760-9e26-50ab009ac011'
and `theme_installation`.`deleted_at` is null
limit
1
Modules\ThemeStoreDB\Entities\ThemeInstallation Object
(
[table:protected] => theme_installation
[attributes:protected] => Array
(
[id] => 35
[theme_store_theme_id] => 21
[original_theme_id] =>
[theme_id] => 96b1c8b9-5b18-4760-9e26-50ab009ac011
[original_wp_theme_id] => 0
[wp_theme_id] => 6
[theme_name] => brooklyn
[theme_custom_name] => brooklyn 6 2
[type] => 1
[role] => unpublished
[processing] => 0
[processing_failed] => 0
[created_at] => 2022-07-04 02:53:29
[updated_at] => 2022-12-09 03:04:36
[deleted_at] =>
)
)
