laravel 实现数据备份

7 篇文章 0 订阅

laravel有时候需要快速备份表,可参考代码如下:

需要新建一个备份库


    public function backupTable($table, $backupTable = false, $connectionName = 'mysql', $backupConnection = 'mysql_backup')
    {
        $sourceConnect = DB::connection($connectionName);
        $sourceDatabaseName = $sourceConnect->getDatabaseName();
        $connection = DB::connection($backupConnection);
        $backupDatabaseName = $connection->getDatabaseName();
        try {
            $baseTable = $backupTable ? $backupTable : "backup_tb_$table" . "_" . date('YmdHis');
            $backupTable = $baseTable;
            $count = 1;
            while (Schema::connection($backupConnection)->hasTable($backupTable)) {
                $backupTable = $baseTable . '_' . ($count > 9 ? $count : '0' . $count);
                ++$count;
            }
            $sql = "CREATE TABLE `$backupDatabaseName`.`$backupTable` LIKE `$sourceDatabaseName`.`$table`";
            $connection->statement($sql);
            $sql = "INSERT INTO `$backupDatabaseName`.`$backupTable` SELECT * FROM `$sourceDatabaseName`.`$table`";
            $connection->statement($sql);
        } catch (\Exception $e) {
            throw new \Exception("全表备份数据异常:$table" . ", " . $e->getMessage() . $e->getTraceAsString(), ExceptionCode::ERROR_INTERNAL);
        }
    }


快速备份数据,代码参考如下:


    public function backupData($table, $data, $backupTable = false, $connectionName = 'mysql', $backupConnection = 'mysql_backup')
    {
        $sourceConnect = DB::connection($connectionName);
        $sourceDatabaseName = $sourceConnect->getDatabaseName();
        $connection = DB::connection($backupConnection);
        $backupDatabaseName = $connection->getDatabaseName();
        try {
            $baseTable = $backupTable ? $backupTable : "backup_dt_$table" . "_" . date('YmdHis');
            $backupTable = $baseTable;
            $count = 1;
            while (Schema::connection($backupConnection)->hasTable($backupTable)) {
                $backupTable = $baseTable . '_' . ($count > 9 ? $count : '0' . $count);
                ++$count;
            }
            $sql = "CREATE TABLE `$backupDatabaseName`.`$backupTable` LIKE `$sourceDatabaseName`.`$table`";
            $connection->statement($sql);
            if (!is_array($data)) {
                $data = $data->toArray();
            }
            $connection->table($backupTable)->insert($data);
        } catch (\Exception $e) {
            throw new \Exception("备份数据异常:$table" . ", " . $e->getMessage() . $e->getTraceAsString(), ExceptionCode::ERROR_INTERNAL);
        }
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值