微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sqlserver 存储过程备份

create proc p_backupdb    @dbname sysname='',--要备份的数据库名称,不指定则备份当前数据库    @bkpath nvarchar(260)='',--备份文件的存放目录,不指定则使用sql认的备份目录    @bkfname nvarchar(260)='',--备份文件名,文件名中可以用\dbnAME\代表数据库名,\DATE\代表日期,\TIME\代表时间    @bktype nvarchar(10)='DB',--备份类型:'DB'备份数据库,'DF' 差异备份,'LOG' 日志备份    @appendfile bit=1 --追加/覆盖备份文件    as    declare @sql varchar(8000)    if isnull(@dbname,'')='' set @dbname=db_name()    if isnull(@bkpath,'')='' set @bkpath=dbo.f_getdbpath(null)    if isnull(@bkfname,'')='' set @bkfname='\dbnAME\_\DATE\_\TIME\.BAK'    set @bkfname=replace(replace(replace(@bkfname,'\dbnAME\',@dbname)   ,'\DATE\',convert(varchar,getdate(),112))   ,'\TIME\',replace(convert(varchar,108),':',''))    set @sql='backup '+case @bktype when 'LOG' then 'log ' else 'database ' end +@dbname    +' to disk='''+@bkpath+@bkfname    +''' with '+case @bktype when 'DF' then 'DIFFERENTIAL,' else '' end    +case @appendfile when 1 then 'NOINIT' else 'INIT' end    print @sql    exec(@sql)    go    exec p_backupdb @bkpath='F:\',@bkfname='db_\DATE\_db.bak'  

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

相关推荐