laravel按不同条件批量更新不同数据记录一下

laravle按不同条件批量更新不同数据记录一下

laravel中DB类中支持批量插入但是没有批量更新语句
如果当需要批量修改数据时,如果用循环来一条一条更新的话极大的消耗资源
下面为批量更新方法,建议分组执行 一组10-20条记录同时更新

/**
     * 批量更新
     * @param string $whereColumn 条件字段 最好用id主键
     * @param array $rows 批量修改的数据 每一行中必须包含条件列与值 例如 $rows = [['id'=>1,'image'=>'xxx','name'=>'xxx'],['id'=>2,'image'=>'xxx','name'=>'xxx','info'=>'xxxx'],['id'=>3,'其他列1'=>'xxx','其他列2'=>'xxx','其他列3'=>'xxxx']] 每行可修改不同数据
     * @return false|int 成功返回影响行数 失败返回false
     * @throws \Exception
     */
    public function updateBatch(string $whereColumn = 'id', array $rows = [])
    {
   
        if (empty($rows)) {
   
            throw new StatusTagException("data_notfound");
        }
        $tableName = DB::getTablePrefix() . $this->getTable(); // 表名


        // 取出所有需要更新的列
        $updateColumn = [];
        foreach ($rows as $row){
   
            $updateColumn = array_merge($updateColumn,array_keys($row));
        }
        // 去重复
        $updateColumn = array_unique($updateColumn);


        // 拼接sql语句
        $updateSql = "UPDATE " . $tableName . " SET ";
        $sets  = [];
        $bindings = [];
        $isExists =<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Laravel 模型数据更新后,如果你的应用程序中使用了缓存来提高性能,那么你可能需要在更新模型后更新缓存。这可以通过在模型的 `saved` 事件中实现来完成。 在 `saved` 事件中,可以通过 `cache` 函数来更新缓存。例如,如果你有一个缓存了模型数据的缓存键名为 `my_model_cache_key`,那么可以在 `saved` 事件中更新该缓存: ```php class MyModel extends Model { protected static function boot() { parent::boot(); static::saved(function ($model) { // 更新模型缓存 Cache::put('my_model_cache_key', $model, 60); }); } } ``` 在上面的例子中,当模型被更新后,会触发 `saved` 事件,该事件会将模型作为参数传递给回调函数。在回调函数中,通过 `Cache::put` 方法来更新缓存,将模型数据存储到缓存中。 需要注意的是,如果你在应用程序中使用了缓存,那么你需要在更新模型的操作之前清除缓存,否则更新后的数据可能无法立即反映在你的应用程序中。你可以在模型的 `deleting` 事件中清除缓存,如下所示: ```php class MyModel extends Model { protected static function boot() { parent::boot(); static::deleting(function ($model) { // 删除模型缓存 Cache::forget('my_model_cache_key'); }); } } ``` 在上面的例子中,当模型被删除时,会触发 `deleting` 事件,该事件会将模型作为参数传递给回调函数。在回调函数中,通过 `Cache::forget` 方法来清除缓存。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值