当前位置:首页 > PHP教程 > php应用 > 列表

PHP实现更新中间关联表数据的两种方法

发布:smiling 来源: PHP粉丝网  添加日期:2021-04-10 15:44:24 浏览: 评论:0 

这篇文章主要介绍了PHP实现更新中间关联表数据的两种方法,在进行多表操作时比较有参考价值,需要的朋友可以参考下

本文以示例形式展示了PHP实现更新中间关联表数据的两种方法。分享给大家供大家参考之用。具体方法如下:

首先,中间关联表:这里的中间表只存表1的主键和表2的主键,即多对多的形式。

执行数据添加和删除为框架内部方法,不属于思路部分。

方法一:先全部删除旧数据,后添加新数据

  1. $res = $this->classes->classEdit($id$data);  //修改主表数据 
  2. if($res
  3.   //先删除关联表数据 
  4.   $bool = $this->lesson_classes->lessonClassesDel($id); 
  5.   if($bool
  6.   { 
  7.     //循环组装条件,添加数据 
  8.     foreach($lesson_ids as $val
  9.     { 
  10.       $arr = array('class_id'=>$id'lesson_id'=>$val);    //数据 
  11.       $res = $this->lesson_classes->lessonClassesAdd($arr);  //执行添加 
  12.     } 
  13.   } 
  14.   $this->show_tips('操作成功!'); 
  15. else 
  16.   $this->show_tips('操作失败!'); 

使用该方法弊端:大批量删除数据这块儿不安全,存在一定程度的安全隐患。

方法二:只添加需要的,只删要删的

  1. //库中查出的旧数据:$arr_old (处理过的一维数组) 
  2. //提交过来的新数据:$arr_new (得到的一维数组) 
  3.  
  4. $intersect = array_intersect($arr_old$arr_new);   //交集(需要保留的部分,不用处理) 
  5. $result_del = array_diff($arr_old$intersect);    //旧数据中需要删除的 
  6. $result_add = array_diff($arr_new$intersect);    //新数据中需要增加的 
  7.  
  8. //添加新增数据 
  9. if($result_add && is_array($result_add)) 
  10.   foreach($result_add as $val
  11.   { 
  12.     $data_add = array('class_id'=>$id'lesson_id'=>$val);       //数据 
  13.     $bool_add = $this->lesson_classes->lessonClassesAdd($data_add);  //执行添加 
  14.   } 
  15.  
  16. //删除需要清除的数据 
  17. if($result_del && is_array($result_del)) 
  18.   foreach($result_del as $val
  19.   { 
  20.     $bool_del = $this->lesson_classes->lessonClassesDel($id$val); //执行删除 
  21.   } 
  22. if($bool_add && $bool_del
  23.   $this->show_tips('操作成功!'); 
  24. //www.phpfensi.com 
  25. else 
  26.   $this->show_tips('操作失败!'); 

该方法特点:有针对性的添加数据和删除数据,较第一种方法,安全性高

希望本文所述对大家的PHP程序设计有所帮助。

Tags: PHP更新关联表

分享到: