thinkphp5产品添加多个规格属性
taotaoit ThinkPHP5.1 2024-04-28 675 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

7173573 2649 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (254)
Mysql (58)
DedeCms (33)
jQuery (67)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)

thinkphp5产品添加多个规格属性

修改产品的时候,以前是直接删除规格表中,相关产品的全部数据,

然后重新添加规格信息,

但是这样如果之前有规格id属性已经使用,则会造成数据丢失,

所以应该在原来的基础上修改,而不是删除。

所以,在传递规格属性信息的时候,带着主键id,这样保存数据库的时候,会自动判断是新增还是修改

如果前台删除了某个规格属性,则不会传递信息过来,
则循环保存结果,删除属于该产品但在结果中不存在的规格主键id

代码

$rs = $goods->save(); // 保存产品信息
                if($rs !== false){
                    $goodsSpecModel = new GoodsSpecModel();                    
                    // 添加规格信息
                    $specIds = []; // 用于存储返回结果集中的主键id
                    if($specList != '' and $specList != NULL){
                        $specArr = json_decode($specList, true);
                        foreach($specArr as &$vo){
                            $vo['goodsId'] = $id;
                        }                        
                        $rs_spec = $goodsSpecModel->saveAll($specArr);
                        foreach($rs_spec as $vo){
                            $specIds[] = $vo['id'];                   
                        }
                    }
                    // 删除前台没有已删除的产品规格
                    $goodsSpecModel->where([['goodsId','=',$id],['id','not in',$specIds]])->delete();
                }

添加修改箱号,箱号单独存一个表,提交修改的时候没有携带箱号表的主键id,需要手动去数据表中查询主键id,比对

$rs = $ApplyModel->where(['id' => $id])->update($applyInfo);
            if($rs != false){
                // 每个箱号单独存储
                if($boxNumRange != '' and $boxNumRange != ','){
                    $boxIds = []; // 用于存储返回结果集中的主键id
                    $boxArr = [];
                    $boxNumRangeArr = explode(',',$boxNumRange);
                    // 获取以前添加的箱号id
                    $rs_boxNum = $ApplyBoxModel->where([['applyId','=',$id],['isDel','=',0]])->column('id','boxNum');
                    for($i = $boxNumRangeArr[0]; $i <= $boxNumRangeArr[1]; $i++){
                        if(array_key_exists($i,$rs_boxNum)){
                            $boxArr[] = [
                                'id' => $rs_boxNum[$i],
                                'applyId' => $id,
                                'boxNum' => $i,
                            ];
                        }else{
                            $boxArr[] = [
                                'applyId' => $id,
                                'boxNum' => $i,
                            ];
                        }
                    }
                    $rs_box = $ApplyBoxModel->saveAll($boxArr);
                    foreach($rs_box as $vo){
                        $boxIds[] = $vo['id'];                   
                    }
                    // 删除修改后已经不存在的箱号
                    $ApplyBoxModel->where([['applyId','=',$id],['id','not in',$boxIds]])->update(['isDel' => 1]);
                }            
            }

版权声明:本站原创文章,允许自由转载。

相关推荐
Non-static method think\Config::get() should not be called statically
ThinkPHP5.1 | 2018-12-29 10782
原来是这样use think\Config; 改成这样use think\facade\Config; 下面是官方手册的解释 配置获取 要使用Config类,首先需要在你的类文件中引入 use think\facade\Config; 或者(因为系统做了类库别名,其实就是调用think\facade\Config) u...
thinkPHP5 order多条件排序
ThinkPHP5.1 | 2017-10-24 10684
总结如下: //单一条件排序 $user = $this->where(['parentId'=>0)->field('userId,userName,userSort,isShow')->order('userSort', 'asc')->select(); //多个条件排序,可以多加一个order...
评论:0条
评论加载中...
发表评论