我在rules()方法的模型中有3个场景,我想在2个场景中使用规则,
[['username', 'email', 'password'], 'required', 'on' => self::SCENARIO_REGISTER]
Run Code Online (Sandbox Code Playgroud)
我阅读了指南,还没有找到一种方法同时将规则绑定到2个场景?有没有办法做到这一点?
我有3个表.例如,文章表,标签表,数据库中的article_tag表.文章和标签有NM关系.
当我需要添加新文章时,使用Yii2的活动记录的link()方法将关系保存到联结表,它可以正常工作.
但是当我需要更新联结表时.如果我再次调用文章上的link()方法.不起作用.下面是我的代码和错误信息.
$tag_ids = Yii::$app->request->post('Article')['tags'];
foreach ($tag_ids as $value) {
$tag = Tag::findOne($value);
$model->link('tags', $tag);
}
SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry '13-1' for key 'PRIMARY'
The SQL being executed was: INSERT INTO `article_tag` (`article_id`, `tag_id`) VALUES (13, 1)
Run Code Online (Sandbox Code Playgroud)
我是否需要删除联结表中的所有数据然后使用link()来更新它?或者Yii2中有一些我缺少的功能?
------------------------更新------------------------- ----------------
看来我需要自己用纯sql来做.我想到的最简单的方法是首先删除联结表中的数据,然后使用link()再次填充数据透视表.这很简单,但会搞砸索引.桌子也快速增长.第二种方法是读取每条记录然后决定保留或删除它.然后添加必要的数据.这样会使它更复杂.需要更多的代码.
----------------再次更新我写了一个函数------------------------
public function syncTags($new_tag_ids){
$old_tag_ids = ArrayHelper::getColumn($this->tags, 'id');
$tag_to_delete = array_diff($old_tag_ids, $new_tag_ids);
$tag_to_add = array_diff($new_tag_ids, $old_tag_ids);
if($tag_to_delete){
//delete tags
Yii::$app->db->createCommand()
->delete('article_tag', ['article_id' => $this->id, 'tag_id' => $tag_to_delete])
->execute();
}
if($tag_to_add){
//link new tag assisoated with …Run Code Online (Sandbox Code Playgroud)