前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Laravel 自定义批量操作函数封装

Laravel 自定义批量操作函数封装

作者头像
Mandy的名字被占用了
发布2021-01-13 10:30:54
7560
发布2021-01-13 10:30:54
举报

文章前导

在使用 Laravel 框架时发现框架的模型无法支持批量创建数据和批量修改数据。于是乎就自己封装了一个批量添加和批量修改数据的方法。只需要封装一个基础模型,让该基础模型 extend Model(框架自带的模型),其他的模型继承你的基础模型即可,全局调用。

示例演示

函数封装
代码语言:javascript
复制
use Illuminate\Database\Eloquent\Model;

class BaseModel extends Model
{
    public $timestamps = true;

    protected $dateFormat = 'U';

    CONST CREATED_AT = 'create_time';

    CONST UPDATED_AT = 'update_time';
    
    /**
     * 批量添加
     * @param string $tableName 数据表名
     * @param array $info 插入的数据
     * @return bool
     * @author kert
     */
    public function batchInsert(string $tableName, array $info): bool
    {
        $timeArray = [
            'create_time' => time(),
            'update_time' => time(),
        ];
        array_walk($info, function (&$value, $key, $timeArray) {
            $value = array_merge($value, $timeArray);
        }, $timeArray);
        return DB::table($tableName)->insert($info);
    }
    
    /**
     * 批量更新
     * @param string $tableName 数据表名
     * @param array $info 更新的数据
     * @return int 受影响的行数
     * @author kert
     */
    public function batchUpdate(string $tableName, array $info)
    {
        try {
            if (count($info) > 0) {
                $firstRow        = current($info);
                $updateColumn    = array_keys($firstRow);
                $referenceColumn = isset($firstRow['id']) ? 'id' : current($updateColumn);
                unset($updateColumn[0]);
                $updateSql = "UPDATE " . $tableName . " SET ";
                $sets      = [];
                $bindings  = [];
                foreach ($updateColumn as $uColumn) {
                    $setSql = "`" . $uColumn . "` = CASE ";
                    foreach ($info as $data) {
                        $setSql     .= "WHEN `" . $referenceColumn . "` = ? THEN ? ";
                        $bindings[] = $data[$referenceColumn];
                        $bindings[] = $data[$uColumn];
                    }
                    $setSql .= "ELSE `" . $uColumn . "` END ";
                    $sets[] = $setSql;
                }
                $updateSql .= implode(', ', $sets);
                $whereIn   = collect($info)->pluck($referenceColumn)->values()->all();
                $bindings  = array_merge($bindings, $whereIn);
                $whereIn   = rtrim(str_repeat('?,', count($whereIn)), ',');
                $updateSql = rtrim($updateSql, ", ") . " WHERE `" . $referenceColumn . "` IN (" . $whereIn . ")";
                return DB::update($updateSql, $bindings);
            }
            return 0;
        } catch (\Exception $e) {
            return $e->getMessage();
        }
    }
  }
函数调用
代码语言:javascript
复制
use BaseModel;

clasee User extends BaseModel
{
  protected $table = 'user';
  
  public function insert(arry $info):bool
  {
     return $this->batchInsert((string)$this->getTable(), (array)$info);
  }
  
  public function update(array $info):bool
  {
    return $this->batchUpdate((string)$this->getTable(), (array)$info);
  }
}
数据格式
代码语言:javascript
复制
// 批量添加数据格式
$addData = [
  ['name' => '张三', 'age' => 12, 'sex' => '男'],
  ['name' => '张三', 'age' => 12, 'sex' => '男'],
  ['name' => '张三', 'age' => 12, 'sex' => '男'],
  ['name' => '张三', 'age' => 12, 'sex' => '男'],
];
// 批量更新数据格式
$updateData = [
  ['id' => 1, name' => '张三', 'age' => 12, 'sex' => '男'],
  ['id' => 2, 'name' => '张三', 'age' => 12, 'sex' => '男'],
  ['id' => 3, 'name' => '张三', 'age' => 12, 'sex' => '男'],
  ['id' => 4, 'name' => '张三', 'age' => 12, 'sex' => '男'],
];
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-12-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 卡二条的技术圈 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章前导
  • 示例演示
    • 函数封装
      • 函数调用
        • 数据格式
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档