在 Laravel 6 中,设置与获取同一个模型的自关联
1、表存在 2 个字段:original_theme_id、theme_id,字段 original_theme_id 的值源自于表中的另一条记录的 theme_id。如图1
2、在模型中设置一对一的反向关联。代码实现如下
/** * 获取此主题安装所属原始的主题安装 * @return BelongsTo */ public function originalThemeInstallation() { return $this->belongsTo('Modules\ThemeStoreDB\Entities\ThemeInstallation', 'original_theme_id', 'theme_id'); }
3、获取关联属性的代码实现,生成的 SQL
$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
4、打印结果,符合预期
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] => ) )
近期评论