PHP编程:ThinkPHP添加更新标签的方法
《ThinkPHP添加更新标签的方法》要点: PHP学习本篇章节讲解ThinkPHP添加更新标签的办法.分享给大家供大家参考.具体分析如下: 我们知道,thinkphp的拓展案例blog,只告诉我们怎样去添加标签tag,却没有删除和更新标签的办法,我在前面的《彻底删除thinkphp3.1案例blog标签的办法》为拓展案例blog写了一个删除标签的办法,接下来将写一个标签的更新办法. 一般情况下,我们写博客后,很少去改动标签了,但是如果我们改动标签如,删除,添加,减少标签怎么办呢?这无疑造成think_tag和think_tagged两个表垃圾信息的积累,好了,言归正转. 在更新标签时我们来了解两个参数: $oldtags:更新前,存在thinphp_tag表中标签 $newstags:更新时,插入thinphp_tag之前,表单提交过来的标签 更新文章时,标签可能会有以下几种变化: 1、$newstags与$oldtags部分相同-> 添加或减少或修改标签,标签的个数和名称和原来部分相同. 2、$newstags与$oldtags完全相同->不修改标签 3、$newstags与$oldtags完全不同 ->添加或减少标签,并且标签的个数和名称和原来完全不同 对于2我们只要通过判断比较过滤即可,对于1、3通过判断比较后,再作删除或添加处理: 删除:要删除的标签名,在thinphp_tag已存在,当标签的count=1时,就把它删除掉,当count>1时,就减少1(count-1). 添加:要添加的标签名称,如果thinphp_tag表中已存在则count(count >1)在原来的基础上+1即count+1,如果不存在(count =0),则添加新标签,count+1.具体函数如下:
代码如下:
public function updateTag($vo,$module) {?
?$recordId= trim($vo['id']);? ? if($vo['keywords']==''){//如果没有标签,则把原来的标签删除? ???? $this->deltag($recordId);????? ?? }else{? ????? $newtags = explode(' ',$vo['keywords']);//获取更新的标签并转为数组(keywords是这里的标签字段,在thinkphp的拓展案例blog为tags,注意) ? ?? $condition['recordId'] = $recordId;//当有多个标签时,将查询多篇日记,而不是一篇? ? ?$tagged=M('Tagged');? ? ? $tag=M('Tag');?????????? ? ? $taggedlist= $tagged->where($condition)->select();? ? if($taggedlist !==false){? ? foreach ($taggedlist as $key => $value) {? ? ? $tagId=trim($value['tagId']);? ? ? $tagvo=$tag->where('id='.$tagId)->find();? ? ? $oldtags[]=$tagvo['name'];//获取原来的标签? ? ? }???? ? ?? $result=count(array_diff(array_diff($newtags,$oldtags),array_diff($oldtags,$newtags)));????? ? ?? $result1=count(array_diff($newtags,$oldtags));//返回更新前后TAG的差值数? ? ? $result2=count(array_diff($oldtags,$newtags));//返回更新前后TAG的差值数 ? ? if(($result1 !== $result2) || ($result !==0)){//2与原来的完全相同->过滤掉???????????? ? ?? $array_intersect=array_intersect($oldtags,$newtags);//取得交值? ? ?? $oldtags_diff=array_diff($oldtags,$array_intersect);//原来的标签,被更新后已无用,需要删除的? ? ??? $newtags_diff=array_diff($newtags,$array_intersect);//修改的标签,需要添加的? ? //删除或者count-1???? ? ???? if(count($oldtags_diff) !==0){?? ? ???? foreach ($oldtags_diff as $name) {? ? ???? $tagvo=$tag->where("module='$module' and name='$name'")->find();? ? ???? $count=intval($tagvo['count']);//获取标签的数量? ? if($count==1){? ? ??? $tag->where('id='.$tagvo['id'])->delete();? ? ??? $tagged->where('tagId='.$tagvo['id'].' and recordId='.$recordId)->delete();? ? ?}elseif($count > 1){? ?? $tag->where('id='.$tagvo['id'])->setDec('count',1);//标签数量减1? ? ?? $tagged->where('tagId='.$tagvo['id'].' and recordId='.$recordId)->delete();//删除tagged中相关数据?? ?} ? } }? //添加更新的标签??? ? if(count($newtags_diff) !==0){? ? ?? foreach ($newtags_diff as $v) {? ? ?????? $v = trim($v);?????????? ? ?????? if (!emptyempty($v)) {? ? ??????? // 记录已经存在的标签? ? ???? $map['module'] = $module;? ? ??????? $map['name'] = $v;? ? ??????? $tagg = $tag->where($map)->find();? ? ?????? if ($tagg) {//如果现在保存的标签与之前相同的标签累加? ? ?????? $tagId = $tagg['id'];? ? ????????? $tag->where('id=' . $tagg["id"])->setInc('count',1);//count统计加1(这个函数有三个参数,默认加1)? ? ????????? } else {//如果是新添的标签,标签+1? ? ?????????????????? $t = array();? ? ?????????????????? $t["name"] = $v;? ? ?????????????????? $t["count"] = 1;? ? ?????????????????? $t["module"] = $module;? ? ?????????????????? $result = $tag->add($t);? ? ?????????????????? $tagId = $result;? ? ??????????? }? ????? }? ???????????????? //记录tag信息? ??? $t = array();? ? ????? $t["module"] = $module;? ? ????? $t["recordId"] = $recordId;//保存news的ID? ? ????? $t["tagTime"] = time();? ? ????? $t["tagId"] = $tagId;//保存tag的ID? ? ????? $tagged->add($t);? ? ???? }? ? ??? }?? ???? }? ???? }? ???? }? } 使用办法:
代码如下:
public? function update() {?
$Blog=D('Blog');? $vo=$Blog->create();? $this->updateTag($vo,'Blog');//更新前调用? if (false === $vo) {? ?$this->error($Blog->getError());? ???? }? ?? // 更新数据? ?? $list = $Blog->save();? ?? if (false !== $list) {? ???? //print_r($list);? ?????? ???? $this->success('编辑成功!');? ?? } else {? ?????? //错误提示? ?????? $this->error('编辑失败!');? ?? }? } 希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助. 《ThinkPHP添加更新标签的方法》是否对您有启发,欢迎查看更多与《ThinkPHP添加更新标签的方法》相关教程,学精学透。编程之家 52php.cn为您提供精彩教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |