Yii2.0一括更新および一括挿入


一括更新
方法1.
/**
     *         
     * @param array $condition
     * $condition = ['advertise_id' => '','status' => '', 'weekdays'=>[1,2,3]]     
     * $params = ['status' => '']
     * @param $params
     * @return bool
     */
    public function batchUpdateAdSchedule($condition = [], $params)
    {
        if (count($condition) == 0 || !is_array($condition) || count($params) == 0) {
            return false;
        }
        $conditions = ' 1 = 1 ';
        $bind = [];
        if (array_key_exists('advertise_id', $condition) && !empty($condition['advertise_id'])) {
            $conditions .= ' AND `advertise_id` = :advertiseId';
            $bind['advertiseId'] = $condition['advertise_id'];
        }
        if (array_key_exists('status', $condition) && !empty($condition['status'])) {
            $conditions .= ' AND `status` = :status';
            $bind['status'] = $condition['status'];
        }

        $result = AdvertiseSchedule::updateAll($params, $conditions, $bind);

        return $result > 0 ? true : false;
    }
方法2.
/**
     *         
     * @param $params
     * @return bool|int
     * @throws \yii\db\Exception
     */
    public function batchUpdateSalesNum($params)
    {
        if (count($params) == 0 || !is_array($params)) {
            return false;
        }
        $sql = '';
        foreach ($params as $key => $value) {
            $sql .= 'UPDATE `morefun`.`mbb_goods` SET `sale_num` = `sale_num` -' . $value['amount'] . ' WHERE `id` =' . $value['goods_id'] . ';';
        }

        $result = Yii::$app->db->createCommand($sql)->execute();

        return $result == 1 ? true : false;
    }

一括挿入
/**
     *     
     * @param $params
     * @return int
     * @throws \yii\db\Exception
     */
    public function batchAddShopClassConn($params)
    {
        $connection = Yii::$app->db;
        $queryBuilder = $connection->queryBuilder;
        /*$sql = $queryBuilder->batchInsert('user', ['name', 'age'], [
            ['Tom', 30],
            ['Jane', 20],
            ['Linda', 25],
        ]);*/
        $sql = $queryBuilder->batchInsert(shopClassConn::tableName(),
            ['shop_id', 'class_id'], $params);

        return $connection->createCommand($sql)->execute();
    }