如何高效的使用PowerShell备份数据库

如何高效的使用PowerShell备份数据库

初始脚本

Get-SqlDatabase -ServerInstance localhost |
Where { $_.Name -ne 'tempdb' } |
Backup-SqlDatabase

 


 

使用上面的命令我们就能每天备份数据库到指定路径去。当然,这只是一个实例,加入打算备份每一个数据库在备份在各自的数据库实例的服务器上,又该如何修改上面的语句那?

目的是批量备份多个实例的数据库,注意这里需要提前把数据库实例存储在一个地方,然后循环遍历出来,代码如下:

foreach $RegisteredSQLs IN dir -recurse SQLSERVER:\SQLRegistration\'Database Engine Server Group'\Host\ | where {$_.Mode -ne 'd'} )
  {
  Get-SqlDatabase -ServerInstance $RegisteredSQLs.Name |
  Where { $_.Name -ne 'tempdb' } |
  Backup-SqlDatabase
  }

 

代码可是真心简短。当然这不足以促使你用PS来替代现有的数据库备份,只是提供了一个一次性备份数据库的简便方式。对于数据库的常规备份来说,你或许不会特别担心,因为这些备份可能由系统管理员或者SAN来负责。假如你的工作中包含了备份数据库,那么使用PowerShell来备份数据库就是一种值得使用的方式了,尤其是当你数据库服务器上都有PowerShell的时候。

这是PowerShell最为重要的技巧之一

接下来,考虑当需要一次性备份数据库时,大多数时候我遇到的备份都是只备份部分数据库,因此按需求从一个列表中备份数据库是一个不错的方式。型号ps有一个叫做Out-GridView的命令,方便我们做这样的操作。上面的脚本中使用where子句,这里我们可以使用Out-GridView -PassThru代替where,并保证结尾用一个“|”来结束。代码如下:

Get-SqlDatabase -ServerInstance localhost |
Out-GridView -PassThru |
Backup-SqlDatabase

对我而言-PassThru 参数是个非常有用的命令参数。方便我们仅仅通过一个参数修改完成命令。上面的脚本中这个参数其实就是数据库名称。进一步而言也可能是数据表,SQL Server Agent Jobs,CSV 文件等等。

Out-GridView 如何使用

下面这个例子使用了Out-GridView 命令,这个场景下,我选择三个数据库,然后会只备份我选择的三个。

<span>如何高效的使用PowerShell备份数据库</span>

 

另一个很有用的功能就是过滤。如果使用了过滤栏,将会查询每一个展示名字中包含我输入的文字的数据库。为了精确查找,我们可以点击“Add Criteria”来选择过滤的字段,这样就能只过滤数据库的名字。

<span>如何高效的使用PowerShell备份数据库</span>

 

接下来点击DW词条,会展示数据库查询后的结果,并高亮选中行。

<span>如何高效的使用PowerShell备份数据库</span>

 

一旦点击ok,将会看到4个数据库被自动备份。

<span>如何高效的使用PowerShell备份数据库</span>

PowerShell 变得更容易

如果你已经相信PS至少对于热备份是更简便的备份方式,我接下来在提供几个备份选项。再次返回最上面的备份例子中,如在备份指令后添加一个-CompressionOption参数,然后空格会显示几个可选参数,如on、off、default等,如图: 

<span>如何高效的使用PowerShell备份数据库</span>

 

注意:这是在PowerShell ISE中,其他的编辑器可能会有不同的弹出参数的的触发。比如我尝试了在PowerShell console 中需要用“Crtl”+空格键才会触发。

  Get-SqlDatabase -ServerInstance localhost |
  Out-GridView -PassThru |
  Backup-SqlDatabase -CompressionOption On

 

通过这个指定可以压缩备份结果,减少不必要的空间。

有趣的脚本参数和实践

这里先要介绍一下-Script ,在备份语句的最后添加这个参数将会允许输出指令,不必等到实际执行的时候。这就让我们可以不用等到备份完成就可以看到脚本。如下图所示,其实我们的PS脚本就是封装了T-SQL脚本而已。

<span>如何高效的使用PowerShell备份数据库</span>

更多备份参数

 

让我们看看这个指令其他的可选参数。如果我想能够了解更多信息可以使用Get-Help指令。

Get-Help -Full Backup-SqlDatabase

也可以找到-ShowWindow 选项,这个参数会弹出帮助文件在一个独立窗口中。使用搜索来方便查找有用的参数。

Get-Help -ShowWindow Backup-SqlDatabase
-BackupAction

使用这个参数可以选择备份数据库、文件或者是日志。默认为完整备份数据库,因此如果你不指定那就为完整备份。如果打算做一个差异备份,使用-Incremental 参数。

<span>如何高效的使用PowerShell备份数据库</span>

(注意这个可选中没有差异备份,因为差异备份用的是独立参数-Incremental )

-DatabaseFile & –DatabaseFileGroup

Backup-SqlDatabase 指令还能够备份单一数据文件或者文件组。如果选择Files作为-BackupAction 参数的可选项,你会需要增加-DatabaseFile或者 -DatabaseFileGroup ,根据数据文件或者文件组名称来备份。

-BackupFile

现在,你已经选择了备份的类型以及备份内容。默认情况是备份为.bak后缀的文件。这是附加备份这样可以不删除文件的情况下附加备份,相应的空间占用会越来越大。这个时候你可以用-BackupFile 参数来修改路径,或者直接备份到Azure存储。

如果需要找到默认备份实例的默认备份路径,可以执行下面的命令:

(Get-Item sqlserver:\sql\localhost\default\).BackupDirectory

 

对于备份文件的名字我一般采用日期模式,这样确保文件不会充满。使用下面来获得名字:

Get-Date -UFormat %Y%m%d%H%M

综上,我们需要添加一个循环所有备份语句指令,以便于我们可以修改备份文件名字。详细代码如下:

<# 备份素有数据库并提供包含文件和日期的文件名 *>
Get-SqlDatabase -ServerInstance localhost |
Where { $_.Name -ne 'tempdb' } | foreach{
Backup-SqlDatabase -DatabaseObject $_ -CompressionOption On -BackupFile "$($_.NAME)_db_$(Get-Date -UFormat %Y%m%d%H%M).bak" -Script}
-ServerInstance & -Database

我们没有提供-ServerInstance & -Database 两个参数,因为例子中使用了Get-SqlDatabase 指令已经传递了包含数据库对象的数组,$_包含了这些参数被以属性的方式保存。Backup-SqlDatabase 指令使用了-DatabaseObject 参数默认去使用。

如果打算备份一个数据库,你可以使用下面的方式而不去调用Get-SqlDatabase。

Backup-SqlDatabase -ServerInstance localhost -Database msdb
-PassThru

这里要说一下pipeline,是否已经在pS中遇到过,并且调试进程。你可以使用-PassThru 参数来看一下管道。这也是提供一个机会来看我们发出命令参数被编译为什么?

Backup-SqlDatabase -ServerInstance localhost -Database msdb -Script -PassThru;

 

<span>如何高效的使用PowerShell备份数据库</span>

 

SQL Provider

最后一个选项就是你可以在SQL Server PowerShell Provider中运行这个命令。能够通过打开PowerShell ISE 得到SQL Provider,然后运行导入模块 Import-Module SqlServer 或者在数据库节点中右击数据库。

<span>如何高效的使用PowerShell备份数据库</span>

这里,您可以通过输入backup-sqldatabase和想要备份的数据库的名称来备份一个数据库。如果您需要在备份完成后启动其他任务,则此选项可能是有益的。或者使用下面的代码样例来备份这个实例中的所有数据库。

<span>如何高效的使用PowerShell备份数据库</span>

If you choose to use the ISE, VS Code (or another rich PowerShell editor) to get to the SQL Provider you will want to start out like this

如果你选择使用ISE获得SQLProvider,执行下面指令:

Import-Module SqlServer;

CD SQLSERVER:\SQL\localhost\default\Databases\
 

总结

我希望利用PS来备份数据库的指令Backup-SqlDatabase cmdlet 能够给大家提供便利。提供给大家一个比起T-sql更便捷的方式。同时可以用它来输出T-sql语句。

本文中显示的所有代码都是使用SqlServer PowerShell模块完成的,该模块使用SSMS 2016(16.5+),而我的机器运行的是PowerShell的5.1版本。除此之外我还测试了2012 在PS3.0也是可行的。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/119683.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 控件anchor和dock属性_控件的常用属性

    控件anchor和dock属性_控件的常用属性在设计窗体时,这两个属性特别有用,如果用户认为改变窗口的大小并不容易,应确保窗口看起来显示的不是那么乱,并编写很多代码来实现这个效果,许多程序解决这个问题都是禁止给窗口重新设置大小这显然是解决问题的最简单的方法,但不是最好的方法,因此引入了Anchor和Dock属性。1、Anchor属性用于指定在用户重新设置窗口的大小时控件应该如何响应,可以指定如果控件重新设置了大小,就根据控件的边界去锁

  • ROC曲线理解

    ROC曲线理解ROC(receiveroperatorcharacteristiccurve,ROC)曲线:即受试者工作特征曲线,是反映敏感度和特异度连续变量的综合指标,用作图法展示两度之间的关系。作图方法:在相关临床研究报告中,若有一个ROC曲线图,将会给人深刻印象,具体做法是:实验结果为计量资料即连续变量,至少计算5个临界点的指标,以敏感度(真阳性率)为Y轴,1-特异度(假阳性率)为X轴,将各点连成…

  • 【SpringBoot】25、SpringBoot中使用Quartz管理定时任务

    【SpringBoot】25、SpringBoot中使用Quartz管理定时任务定时任务在系统中用到的地方很多,例如每晚凌晨的数据备份,每小时获取第三方平台的Token信息等等,之前我们都是在项目中规定这个定时任务什么时候启动,到时间了便会自己启动,那么我们想要停止这个定时任务的时候,就需要去改动代码,还得启停服务器,这是非常不友好的事情直至遇见Quartz,利用图形界面可视化管理定时任务,使得我们对定时任务的管理更加方便,快捷一、Quartz简介Quartz是一个开源的作业调度框架,它完全由Java写成,并设计用于J2SE和J2EE应用中。它提供了巨大的灵活性而不牺牲

    2022年10月22日
  • 阿里云wordpress配置免费ssl证书

    阿里云wordpress配置免费ssl证书本文最后更新于352天前,其中的信息可能已经有所发展或是发生改变。1、登录阿里云,选择产品中的ssl证书如果域名是阿里的他会自动创建dns解析,如果是其他厂商需要按照图片配置,等待几分钟进行验证点击审核,等待签发签发后根据需求下载所需证书我的wordpress是直接买的阿里轻量应用服务器,打开轻量应用服务器的控制台配置域名选择刚申请好的ssl证书在wordpre…

  • 《关于VirtualBox在桥接模式下无法联网 解决方案》

    《关于VirtualBox在桥接模式下无法联网 解决方案》博主遇到了这个问题,百度了大半天还是没有解决到,可能是由于下面链接的文章的标题关键词比较偏,很难精确的定位到此文章,于是博主就决定总结归纳了一下,希望对大家有所帮助。。经过无数次的百度,早已厌倦粘贴党,问牛答马党,错误党,大大的浪费了大家的时间,于是博主开了这篇文章..我们在VBOX上面安装了Linux之后,VBOX默认网络设置是使用NAT模式的,这种方式宿

  • 2022最新Kong插件开发教程[通俗易懂]

    2022最新Kong插件开发教程[通俗易懂]Kong网关插件开发教程

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号