sql server 2008 压缩备份数据库(20g)

 更新时间:2018年03月15日 21:46:41   作者:Sunny秋刀鱼  
这篇文章主要介绍了针对20g数据库的迁移问题,,需要的朋友可以参考下

今天需要把一个省外项目的数据库从服务器上备份、拷贝到本机(跨地域传输数据库备份文件)。

连上VPN,通过远程桌面连接,连接上服务器,发现数据库文件已经有20G以上大小了。

文件太大,公司网络也不稳定,根本不可能通过网络传输过来。

于是,把数据库的恢复模式由“完整”模式设置为“简单”模式,接着收缩数据库,

数据库瞬间由20G变成1G多点。

在SSMS中,新建查询窗口,执行数据库备份语句:

--定义变量,把备份数据库的QL脚本赋值给变量
declare @SqlBackupDataBase as nvarchar(1000)
set @SqlBackupDataBase=N'BACKUP DATABASE Northwind TO DISK = ''D:\Northwind-'+
CONVERT(varchar(11),GETDATE(),112)+REPLACE(CONVERT(varchar(12),GETDATE(),108),':','')+'.bak'''
--备份文件格式:Northwind-20170111132424.bak
exec sp_executesql @SqlBackupDataBase --调用系统存储过程,执行SQL

备份成功后,备份的bak文件有1.16G大小:

接着,兴冲冲地拷贝bak文件到本机,

结果:总是在传输的过程中,传输自动中断。

原因是 网络不稳定,网络的带宽限制。

想想,能不能备份成更小的bak文件呢?

最后用到了sql server 2008 以上版本的数据库的新特性:压缩备份数据库。

其实就是在备份数据库的语句上加上 “with STATS = 1,compression”,

完整压缩备份数据库语句如下:

--定义变量,把备份数据库的QL脚本赋值给变量
declare @SqlBackupDataBase as nvarchar(1000)
set @SqlBackupDataBase=N'BACKUP DATABASE Northwind TO DISK = ''D:\Northwind-'+
CONVERT(varchar(11),GETDATE(),112)+REPLACE(CONVERT(varchar(12),GETDATE(),108),':','')+'.bak'''
+'with STATS = 1,compression'
--备份文件格式:Northwind-20170111132424.bak
exec sp_executesql @SqlBackupDataBase --调用系统存储过程,执行SQL

备份成功后,发现备份的bak文件只有160MB大小:

最后顺利地把这个数据库备份文件拷贝并还原到本机数据库。

相关文章

  • SQL Server中实现自定义数据加密功能

    SQL Server中实现自定义数据加密功能

    在当今数字化时代,数据安全已成为企业和个人最为关注的问题之一,SQL Server提供了多种数据加密技术,包括透明数据加密(TDE)、备份加密以及列级加密等,本文将详细介绍如何在SQL Server中实现自定义数据加密功能,需要的朋友可以参考下
    2024-08-08
  • SQL Server Reporting Services 匿名登录的问题及解决方案

    SQL Server Reporting Services 匿名登录的问题及解决方案

    这篇文章主要介绍了关于 SQL Server Reporting Services 匿名登录的解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-09-09
  • 数据库复制性能测试 推送模式性能测试

    数据库复制性能测试 推送模式性能测试

    使用了数据库复制的人,首先担心的就是主服务器和备份服务器的性能消耗问题,本人也是对此十分担忧,查了半天,基本上没发现类似的测试说明,就自己测试了一下,下面为测试的结果,仅供参考
    2012-06-06
  • Sql奇技淫巧之ROWNUM伪列的使用

    Sql奇技淫巧之ROWNUM伪列的使用

    本文主要介绍了Sql奇技淫巧之ROWNUM伪列,ROWNUM是一个伪列,它是根据每次查询的结果动态生成的一列递增编号,下面就一起来介绍一下如何使用把
    2023-08-08
  • SqlServer开发神器'SQLPrompt'插件的使用详解

    SqlServer开发神器'SQLPrompt'插件的使用详解

    SQLPrompt是Sql Server 开发智能提示插件,方便查询表结果,避免了开发人员一个个敲查询语句、执行语句等,这篇文章主要介绍了SqlServer数据库开发神器'SQLPrompt插件'的使用说明,需要的朋友可以参考下
    2023-03-03
  • SQL Server中通配符的使用示例

    SQL Server中通配符的使用示例

    这篇文章主要介绍了SQL Server中通配符的使用示例,本文给出多个示例来讲解通配符的使用方法,需要的朋友可以参考下
    2015-07-07
  • SQLAlchemy案例详解

    SQLAlchemy案例详解

    SQLAlchemy 是 Python SQL 工具包和对象关系映射器,为应用程序开发人员提供SQL的全部功能和灵活性,这篇文章主要介绍了SQLAlchemy详解,需要的朋友可以参考下
    2024-04-04
  • MsSql 存储过程分页代码 [收集多篇]

    MsSql 存储过程分页代码 [收集多篇]

    最近发现好多朋友看 mssql存储过程分页的代码,特给大家整理了一些。希望对大家能有所帮助。
    2009-06-06
  • SQL Server降权运行 SQL Server 2000以GUESTS权限运行设置方法

    SQL Server降权运行 SQL Server 2000以GUESTS权限运行设置方法

    由于sql注入问题比较常见,很多黑客都是通过sqlserver数据库漏洞直接获取系统权限,所以sqlserver的安全设置尤为重要,简单简单分享下sqlserver低权限运行方法
    2014-07-07
  • SQL计算用户留存率问题

    SQL计算用户留存率问题

    电商业务中需要计算用户留存情况,在时间维度上可以分为用户次日、多日后的留存情况,本文就来详细的介绍一下如何计算,具有一定的参考价值,感兴趣的可以了解一下
    2024-09-09

最新评论