Thinkphp5.1 循环调用save方法新增或修改数据
web ThinkPHP5.1 2022-07-27 169 0
关于本站

“最难不过坚持”

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

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

2957157 2008 24
最新评论
:zhenbang:
评 Bootstrap通过模态框modal实现图片弹出放大
能不能显示这里当前在播放的视频的文件名?
评 设置video js多视频连续播放
为啥按照你的方法去写完后 提示未定义的hostname?
评 tp6用tp5er实现数据库备份,数据库还原
了解了,应该用超链接去访问 我当时用的是ajax,这回在到你这看看如何用Tp6备份数据库
评 thinkphp6 整合PhpSpreadsheet 导出数据到excel
为什么我执行这个方法 没有下载 ,但用url访问这个页面就可以下载了 是我哪里弄错了吗
评 thinkphp6 整合PhpSpreadsheet 导出数据到excel
文章标签更多
ThinkPHP (225)
Mysql (42)
DedeCms (33)
jQuery (54)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)

Thinkphp5.1 循环调用save方法新增或修改数据

save方法一个比较好的地方是:系统会自动判断需要新增还是更新数据。
主键id有值,则更新;没有主键id或者主键id为null,则新增
有一个需求需要循环增加产品多级分类,并且自动判断更新还是新增。所以用到了foreach循环里面save

结果出错,总是添加1条数据后,就出错了。

后来终于解决了。

// allowField(true) 过滤post数组中的非数据表字段数据
		// isUpdate(true) 更新 isUpdate(false) 新增
		// data($v,true) 这个true不太明白什么意思,但是起关键作用
		foreach($catArr as $k=>$v){
			if(empty($v['catId'])){
				unset($v['catId']);
				$isUpdate = false;
			}else{
				$isUpdate = true;
			}
			$result = $this->allowField(true)->isUpdate($isUpdate)->data($v,true)->save();
		}

附:完整代码:包括查询所有分类,每条分类信息追加参数shopId,组装多级分类,循环调用save

<?php
namespace app\api\model;
/**
 * 店铺新闻分类模型
 */
class ShopArticleCat extends Base {
	protected $pk = 'catId';
  /**
	 * 同步新闻分类
	 */
	public function editArticleCat(){
		$shopId = 400;		
		$shop = [];
		$shop['shopId'] = $shopId;
    // 查询所有分类
		$webCatList = model('article_cat')->field('catId webCatId,catTitle,parentId,isShow,dataSort,industryCatId catId')->select()->toArray();
    // 每条分类信息追加参数shopId-给二维数组元素追加参数
		array_walk($webCatList, function (&$value, $key, $shop) {
			$value = array_merge($value, $shop);
		}, $shop);
    // 组装多级分类
		$webCatList = self::_getTree($webCatList, 0); 
		$data = [];
    // 数组转json
		$data['webCatList'] = json_encode($webCatList);

		$json = $data['webCatList'];
    // json转数组
		$catArr = json_decode($json,true);
    // 循环调用save把多级分类添加到数据库中,自动根据主键id是否存在,判断是新增还是更新
		self::_save($catArr);
	}
	/**
	 * 循环添加多级分类
	 */
	public function _save($arr,$parentId=0){
		foreach($arr as $k=>$v){
			if(empty($v['catId'])){
				unset($v['catId']);
				$isUpdate = false;
			}else{
				$isUpdate = true;
			}
			$v['parentId'] = $parentId;
			$result = $this->allowField(true)->isUpdate($isUpdate)->data($v,true)->save();
			if(!empty($v['children'])){
				self::_save($v['children'],$this->catId);
			}
		}
	}
	/**
	 * 查询次数据库,组装多级分类
	 */
	public function _getTree($data, $parentId){
		$tree = [];
		foreach ($data as $k => $v) {
			if ($v['parentId'] == $parentId) {
				// 再找其下级分类
				$v['children'] = self::_getTree($data, $v['webCatId']);
				$tree[] = $v;
			}
		}
		return $tree;
	}
}

版权声明:本篇文章来源于网络。 来源链接

相关推荐
Non-static method think\Config::get() should not be called statically
ThinkPHP5.1 | 2018-12-29 7574
原来是这样use think\Config; 改成这样use think\facade\Config; 下面是官方手册的解释 配置获取 要使用Config类,首先需要在你的类文件中引入 use think\facade\Config; 或者(因为系统做了类库别名,其实就是调用think\facade\Config) u...
tp5.1排序表达式错误:field(`goodsId`
ThinkPHP5.1 | 2019-07-02 5457
tp5.1排序表达式错误:field(`goodsId` 解决方法: 在V5.1.7+版本开始,如果你需要在order方法中使用mysql函数的话,必须使用下面的方式: Db::table('think_user') ->where('status', 1) ->orderRaw("field(name,'...
评论:0条
评论加载中...
发表评论