In Laravel 6, set the self-association with the same model
1. There are 2 fields in the table: original_theme_id, theme_id, the value of the field original_theme_id is derived from the theme_id of another record in the table. as shown in Figure 1
2. Set a one-to-one reverse association in the model. The code is implemented as follows
/**
* 获取此主题安装所属原始的主题安装
* @return BelongsTo
*/
public function originalThemeInstallation()
{
return $this->belongsTo('Modules\ThemeStoreDB\Entities\ThemeInstallation', 'original_theme_id', 'theme_id');
}
3. Get the code implementation of the associated attribute, the generated 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. Print the results, in line with expectations
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] =>
)
)
