vadymsemeniuk / yii2-many-to-many-ar-level-save-behavior
Behavior for saving many to many relation
Installs: 19 468
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 1
Open Issues: 0
Type:yii2-extension
Requires
- yiisoft/yii2: *
This package is not auto-updated.
Last update: 2024-11-09 20:33:41 UTC
README
Yii2 ManyToMany Active Record Level Behavior
Extension save many-to-many related data
Installation
The preferred way to install this extension is through composer.
Either run
php composer.phar require --prefer-dist vadymsemeniuk/yii2-many-to-many-ar-level-save-behavior "*"
or add
"vadymsemeniuk/yii2-many-to-many-ar-level-save-behavior": "*"
to the require section of your composer.json
file.
Usage
An example of usage could be:
Suppose you have the following schema.
CREATE TABLE `article` ( `id` int(11) NOT NULL AUTO_INCREMENT, `label` varchar(1024) COLLATE utf8_unicode_ci NOT NULL, PRIMARY KEY (`id`), ); CREATE TABLE `tag` ( `id` int(11) NOT NULL AUTO_INCREMENT, `label` varchar(1024) COLLATE utf8_unicode_ci NOT NULL, PRIMARY KEY (`id`), ); CREATE TABLE `article_to_tag` ( `id` int(11) NOT NULL AUTO_INCREMENT, `article_id` int(11) NOT NULL, `tag_id` int(11) NOT NULL, PRIMARY KEY (`id`), KEY `fk-article_to_tag-article_id-article-id` (`article_id`), KEY `fk-article_to_tag-tag_id-tag-id` (`tag_id`), CONSTRAINT `fk-article_to_tag-article_id-article-id` FOREIGN KEY (`article_id`) REFERENCES `article` (`id`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `fk-article_to_tag-tag_id-tag-id` FOREIGN KEY (`tag_id`) REFERENCES `tag` (`id`) ON DELETE CASCADE ON UPDATE CASCADE )
Your code must look like this
use vadymsemenykv\manyToManyBehavior\ManyToManyArLevelSaveBehavior /** * @ property Tag[] $tags */ class Article extends ActiveRecord { public $tagIds = []; public function tableName() { return 'article'; } public function getTags() { return $this->hasMany(Tag::className(), ['id' => 'tag_id']) ->viaTable('article_to_tag', ['article_id' => 'id']); } public function behaviors() { return [ 'manyToManyBehavior' => [ 'class' => ManyToManyArLevelSaveBehavior::className(), 'relations' => [ 'tags' => [ 'modelClass' => Tag::className(), 'attribute' => 'tagIds', 'pkColumnName' => 'id', 'deleteAllRelatedEntriesBeforeSave' => true, ], ], ], ]; } }
class Tag extends ActiveRecord { public function tableName() { return 'tag'; } }
$tag = new Tag(); $tag->id = 1; $tag->label = 'Tag #1'; $tag->save(); $tag = new Tag(); $tag->id = 2; $tag->label = 'Tag #2'; $tag->save(); $article = new Article(); $article->label = 'New article'; $article->tagIds = [1, 2]; $article->save(); $tags = $article->tags; /** * $tags = [ * 0 => object(Tag) * ... * private '_attributes' (yii\db\BaseActiveRecord) => * 'id' => int 1 * 'label' => string 'Tag #1' * ... * 1 => object(Tag) * ... * private '_attributes' (yii\db\BaseActiveRecord) => * 'id' => int 2 * 'label' => string 'Tag #2' * ... * ] */
Advanced usage
For example, if in table article_to_tag
in example above present type_id
column with some additional
identifier - config for behavior may be like this:
public function behaviors()
{
return [
'manyToManyBehavior' => [
'class' => ManyToManyArLevelSaveBehavior::className(),
'relations' => [
'tags' => [
'modelClass' => Tag::className(),
'attribute' => 'tagIds',
'pkColumnName' => 'id',
'deleteAllRelatedEntriesBeforeSave' => true,
'extraColumns' => [
'type_id' => ArticleToTag::TYPE_1
],
'additionalUnlinkCondition' => [
'type_id' => ArticleToTag::TYPE_1,
]
],
],
],
];
}
where extraColumns
will be used in link() method, and additionalUnlinkCondition
will be merged with unlink condition.