对于Thinkphp5可能遇到的保存问题

最近在开发一个酒店小程序的项目,要求要批量修改日历价格,查询出所有的房间后修改的时候总是能保存某几条然后就终止了,代码如下

c 复制代码
 $cmodel = new \app\admin\model\booking\Calendar;
  // 查到对应的数据后进行保存到对应的日历价格里面
        foreach ($houseData as $item) {
            try {
               
                // 查找已有的数据,修改
                $calendar_data = $cmodel
                    ->where('house_id', $item->id)
                    ->where('day_time', $times)
                    ->find();
            
                if ($calendar_data) {
                    $result = $calendar_data->save(['price' => $params['price']]);
                } else {
                    $result = $cmodel->save([
                        'house_id' => $item->id,
                        'day_time' => $times,
                        'price' => $params['price']
                    ]);
                }
                
                if ($result !== false) {
                    $successCount++;
                } else {
                    $failCount++;
                }
            } catch (\Exception $e) {
                $failCount++;
                \think\Log::record('房间日历价格保存失败: 房间ID=' . $item->id . ', 错误=' . $e->getMessage(), 'error');
            }
        }

为题出在那里呢,正常也提示了修改了多少条数据,但是库里不改变。整体如果不注意的话感觉代码没问题,最终的问题就是因为初始话的cmodel,在循环外,在代码执行的时候cmodel,在循环外,在代码执行的时候cmodel,在循环外,在代码执行的时候cmodel存储的还是上一次的数据,所以就导致了问题的产生

c 复制代码
  // 查到对应的数据后进行保存到对应的日历价格里面
        foreach ($houseData as $item) {
            try {
                $cmodel = new \app\admin\model\booking\Calendar;
                // 查找已有的数据,修改
                $calendar_data = $cmodel
                    ->where('house_id', $item->id)
                    ->where('day_time', $times)
                    ->find();
            
                if ($calendar_data) {
                    $result = $calendar_data->save(['price' => $params['price']]);
                } else {
                    $result = $cmodel->save([
                        'house_id' => $item->id,
                        'day_time' => $times,
                        'price' => $params['price']
                    ]);
                }
                
                if ($result !== false) {
                    $successCount++;
                } else {
                    $failCount++;
                }
            } catch (\Exception $e) {
                $failCount++;
                \think\Log::record('房间日历价格保存失败: 房间ID=' . $item->id . ', 错误=' . $e->getMessage(), 'error');
            }
        }

虽然懂开发的人一般不会出现这样的问题,但是也是一个注意点,万一遇到呢 ............

相关推荐
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ5 小时前
Linux 查询某进程文件所在路径 命令
linux·运维·服务器
Moksha2625 小时前
5G、VoNR基本概念
开发语言·5g·php
05大叔7 小时前
网络基础知识 域名,JSON格式,AI基础
运维·服务器·网络
安当加密7 小时前
无需改 PAM!轻量级 RADIUS + ASP身份认证系统 实现 Linux 登录双因子认证
linux·运维·服务器
woho7788998 小时前
不同网段IP的网络打印机,打印、扫描设置
运维·服务器·网络
耗子会飞8 小时前
小白学习固定VM虚拟机的centos服务器的IP
运维·服务器·centos
阿达_优阅达10 小时前
告别手工对账:xSuite 如何帮助 SAP 企业实现财务全流程自动化?
服务器·数据库·人工智能·自动化·sap·企业数字化转型·xsuite
JdayStudy10 小时前
SIR 网络传播仿真软件说明书
开发语言·网络·php
IMPYLH10 小时前
Linux 的 chroot 命令
linux·运维·服务器
克莱因35810 小时前
Linux Cent OS7 at定时任务
linux·运维·服务器