SQL Server数据库远程备份和还原
sqlserver 数据库备份方法
sqlserver 数据库备份方法SQL Server是一款常用的关系型数据库管理系统,用于存储和管理大量的数据。
在使用SQL Server数据库时,数据备份是非常重要的一项工作,可以保证数据的安全性和可恢复性。
本文将介绍SQL Server数据库备份的方法和步骤。
一、全备份全备份是最常用和最基本的备份方式,它将数据库的所有数据和日志都备份到一个文件中。
全备份可以保证数据库的完整性和一致性,同时也可以通过全备份文件来恢复数据库。
进行全备份的步骤如下:1. 打开SQL Server管理工具,连接到目标数据库实例。
2. 在“对象资源管理器”中选择要备份的数据库。
3. 右键点击选中的数据库,选择“任务”-“备份”。
4. 在“备份数据库”对话框中,选择“备份类型”为“完整”,并选择备份文件的路径和名称。
5. 点击“确定”按钮,开始备份数据库。
二、差异备份差异备份是基于全备份的增量备份方式,它只备份上次全备份之后发生变化的数据和日志。
差异备份可以减少备份文件的大小和备份时间,同时也方便了数据恢复操作。
进行差异备份的步骤如下:1. 打开SQL Server管理工具,连接到目标数据库实例。
2. 在“对象资源管理器”中选择要备份的数据库。
3. 右键点击选中的数据库,选择“任务”-“备份”。
4. 在“备份数据库”对话框中,选择“备份类型”为“差异”,并选择备份文件的路径和名称。
5. 点击“确定”按钮,开始备份数据库。
三、事务日志备份事务日志备份是备份SQL Server数据库的事务日志信息,可以用于恢复数据库到某个特定时间点的状态。
事务日志备份可以提供更精确的数据恢复能力,同时也可以释放事务日志空间。
进行事务日志备份的步骤如下:1. 打开SQL Server管理工具,连接到目标数据库实例。
2. 在“对象资源管理器”中选择要备份的数据库。
3. 右键点击选中的数据库,选择“任务”-“备份”。
4. 在“备份数据库”对话框中,选择“备份类型”为“事务日志”,并选择备份文件的路径和名称。
SQLSERVER完整数据库还原(完整恢复模式)
SQLSERVER完整数据库还原(完整恢复模式)数据库完整还原的⽬的是还原整个数据库。
整个数据库在还原期间处于脱机状态。
在数据库的任何部分变为联机之前,必须将所有数据恢复到同⼀点,即数据库的所有部分都处于同⼀时间点并且不存在未提交的事务。
在完整恢复模式下,还原数据备份之后,必须还原所有后续的事务⽇志备份,然后再恢复数据库。
您可以将数据库还原到这些⽇志备份之⼀的特定恢复点。
恢复点可以是特定的⽇期和时间、标记的事务或⽇志序列号 (LSN)。
还原数据库时,特别是在完整恢复模式或⼤容量⽇志恢复模式下,您应使⽤⼀个还原顺序。
还原顺序由通过⼀个或多个还原阶段来移动数据的⼀个或多个还原操作组成。
⼀、将数据库还原到故障点通常,将数据库恢复到故障点分为下列基本步骤:1.备份活动事务⽇志(称为⽇志尾部)。
此操作将创建结尾⽇志备份。
如果活动事务⽇志不可⽤,则该⽇志部分的所有事务都将丢失。
重要在⼤容量⽇志恢复模式下,备份任何包含⼤容量⽇志操作的⽇志都需要访问数据库中的所有数据⽂件。
如果⽆法访问该数据⽂件,则不能备份事务⽇志。
在这种情况下,您必须⼿动重做⾃最近备份⽇志以来所做的所有更改。
2.还原最新完整数据库备份⽽不恢复数据库 (RESTORE DATABASE database_name FROM backup_device WITH NORECOVERY)。
3.如果存在差异备份,则还原最新的差异备份⽽不恢复数据库 (RESTORE DATABASE database_name FROM differential_backup_device WITH NORECOVERY)。
还原最新差异备份可减少必须还原的⽇志备份数。
4.从还原备份后创建的第⼀个事务⽇志备份开始,使⽤ NORECOVERY 依次还原⽇志。
5.恢复数据库 (RESTORE DATABASE database_name WITH RECOVERY)。
此步骤也可以与还原上⼀次⽇志备份结合使⽤。
Sqlserver数据库备份与还原
Sqlserver数据库备份与还原⼀、数据库存储概述1、数据⽂件类型· Primary data files:每个数据库都有⼀个单独的主要数据⽂件,默认以.mdf扩展名。
主要数据⽂件不仅包含数据信息,还包含与该数据库结构相关的信息。
创建数据库时,数据库结构相关信息不仅存在于master数据库中,同时还包含在primary data file上.· Secondary data files⼀个数据库可以有⼀个或者多个⼆级数据⽂件,默认以.ndf为扩展名。
⼀般来说⼆级数据⽂件并不是必须的,因为⼆级数据⽂件不包含⽂件位置等信息。
· Transaction logs: 数据库必须⾄少有⼀个事务⽇志⽂件,默认以.ldf为扩展名。
⽇志是整个数据库的命脉,事务⽇志不可读的话,将⽆法对数据库进⾏任何操作。
当你在数据库上进⾏数据操作时,数据并不是直接写⼊数据⽂件,⽽是先将相关操作信息写⼊事务⽇志⽂件。
当⼀个事务结束时,该事务被标记为已提交,但这也并不意味着数据从⽇志⽂件写⼊了数据⽂件中。
⼀个标记为已提交的事务仅仅意味着所有与该事务相关的元素已经成功完成。
The buffer cache may be updated, but not necessarily the data file.检查点(checkpoint)会周期性的发⽣。
检查点发⽣时,是确认所有已提交的事务,不管是在buffer cache或者事务⽇志中,都被写⼊相关的数据⽂件中。
检查点(checkpoint)可以通过以下⽅式来触发:1、显⽰调⽤checkpoint命令;2、Recover Interval 实例设置的周期达到(⽤来标识多久发⽣⼀次checkpoint)3、做了数据库备份(在简单模式下);4、数据库⽂件结构被改变(在简单模式下);5、数据库引擎被结束。
⼀般来说,写数据的过程是由系统⾃动完成的,如下图所⽰,但数据并不是直接写⼊.mdf或者.ndf ⽂件中,⽽是先将有关变化写⼊事务⽇志中,这也是数据库中的write-ahead机制。
sql 2008数据库还原操作说明
SQL Server 2008数据库还原操作说明一、概述SQL Server 2008是一个强大的数据库管理系统,它提供了多种数据恢复的选项,包括备份和还原。
备份是创建数据库副本的过程,而还原是将备份的副本重新加载到数据库中。
在数据丢失或损坏的情况下,还原操作是非常重要的。
二、还原前的准备在进行还原操作之前,需要确保以下几点:1.确保你有最新的数据库备份。
如果没有备份,那么无法还原数据。
2.确保目标数据库实例已经停止或处于单用户模式。
3.确保你有足够的磁盘空间来存储还原过程中的临时文件。
三、还原操作步骤以下是还原操作的步骤:1.打开SQL Server Management Studio (SSMS),连接到目标数据库实例。
2.在对象资源管理器中,展开服务器节点,然后展开“数据库”节点。
3.右键单击要还原的数据库,然后选择“任务” -> “还原” -> “数据库…”。
4.在“源和恢复类型”页上,选择“从设备”并浏览到包含备份文件的路径。
选择要还原的备份类型(例如,完整、差异或事务日志备份)。
5.在“选择要还原的备份”页上,选择要还原的备份日期和时间。
6.在“选项”页上,根据需要选择其他选项,例如覆盖现有数据库或限制用户访问。
7.单击“确定”开始还原过程。
8.等待还原过程完成。
这可能需要一些时间,具体取决于数据库的大小和系统性能。
9.验证数据库是否已成功还原。
可以尝试连接到数据库并执行一些查询来验证数据是否完整。
四、注意事项在执行还原操作时,需要注意以下几点:1.确保在生产环境之外的测试环境中进行还原操作,以避免对生产数据造成不可逆的损失。
2.在进行还原操作之前,请务必备份当前数据库的副本,以防还原过程中出现任何问题。
SQLServer数据库的备份详细介绍及注意事项
SQLServer数据库的备份详细介绍及注意事项SQL Server 备份前⾔为什么要备份?理由很简单——为了还原/恢复。
当然,如果不备份,还可以通过磁盘恢复来找回丢失的⽂件,不过SQL Server很⽣⽓,后果很严重。
到时候你就知道为什么先叫你备份⼀次再开始看⽂章了。
∩__∩。
本系列将介绍SQL Server所有可⽤的备份还原功能,并尽可能⽤实例说话。
什么是备份?SQL Server基于Windows,以⽂件形式存放资料,所以备份就是Windows上SQL Server相关⽂件的⼀个某个时间点的副本。
根据备份类型的不同,副本的种类和内容也有不同。
备份类型有哪些?SQL Server ⽬前版本中,可⽤的备份类型有:完整数据库备份、差异数据库备份、事务⽇志备份(后称⽇志备份)、⽂件和⽂件组备份、部分备份,根据SQL Server版本不同,有些备份类型不⽀持,另外根据恢复模式的不同,某些备份类型也不⽀持。
什么是恢复模式?很多⼈只把关注点放在备份上⾯,⽽没有在意恢复模式,其实所有的备份都应该从恢复模式作为切⼊点。
恢复模式实际上是⼀个控制备份还原的⾏为的数据库级别选项。
SQL Server 在当前所有发布版本中只有三种恢复模式:简单恢复模式(后⾯简称简单模式),⼤容量⽇志恢复模式(后⾯简称⼤容量模式),完整恢复模式(后称完整模式)。
本⽂从恢复模式开始,提醒⼀下,绝⼤部分的专业属于都会陆续解释,如果读者有不明⽩,可以继续往下看或者上⽹搜索:1.简单模式,Simple recovery model:某些操作可以被最⼩⽇志化。
这种模式下,不⽀持⽇志备份、时间点恢复和页恢复。
且⽂件恢复功能仅限于次要数据⽂件中的只读⽂件。
2.⼤容量⽇志模式,Bulk-logged recovery model:和完整模式类似,有时候可以理解为完整模式于简单模式的过渡模式。
这种模式对某些⼤容量操作进⾏最⼩⽇志化,⽀持完整备份中的备份还原策略,但是由于某些操作被最⼩⽇志化,所以不能保证时间点恢复。
SQLServer数据库备份和恢复
SQLServer数据库备份和恢复作为一位数据库管理员,备份和恢复数据库是日常工作中必不可少的任务。
在SQLServer中,备份和恢复数据库是非常简单而且快速的,但是在备份和恢复过程中需要注意一些要点,本文将对此进行介绍和分析。
一、备份数据库在备份数据库之前,需要了解备份的种类和使用场景。
常见的备份种类有完整备份、差异备份和日志备份。
完整备份是将数据库的所有数据和日志都备份下来,差异备份是在完整备份的基础上备份自上次完整备份之后发生的所有变化,而日志备份是备份从最后一次备份到本次备份之间发生的所有交易记录。
是否进行完整备份,差异备份还是日志备份,取决于数据需要恢复到哪一个时间点以及备份的频率和容量。
完整备份备份的数据和所有交易记录,可以恢复到任意一个时间点;差异备份备份的数据是上次备份之后的所有变化,可以恢复到差异备份之后的任意一个时间点;而日志备份只备份从上次备份到本次备份之间的交易记录,只能在连续的日志备份中进行数据的恢复。
在进行备份之前,需要关闭数据库以保证备份的一致性。
可以使用以下SQL语句进行完整备份:BACKUP DATABASE database_nameTO DISK = 'backup_path\backup_file_name.bak'WITH FORMAT, INIT其中,database_name 是要备份的数据库名称,backup_path 是备份文件的存储路径,backup_file_name 是备份文件的名称。
WITH FORMAT参数表示每次备份都会覆盖之前的备份文件并且重新初始化备份集,INIT参数表示让备份文件从头开始,不保存之前的任何备份数据。
需要进行差异备份时,可以使用以下SQL语句:BACKUP DATABASE database_nameTO DISK = 'backup_path\backup_file_name.diff'WITH DIFFERENTIAL其中,DIFFERENTIAL参数表示进行差异备份。
数据库常用的备份和恢复方法
数据库常用的备份和恢复方法1. 备份方法:使用数据库管理系统自带的备份工具,如MySQL的mysqldump命令或SQL Server的Backup Database语句。
描述:数据库管理系统提供了备份工具,可以将数据库的数据和结构导出为一个备份文件,通常以.sql格式保存。
用户可以定期使用这些备份工具进行全量备份或增量备份。
2. 备份方法:使用文件系统级别的数据复制工具进行备份,如使用rsync或Windows 的文件复制功能。
描述:可以通过文件系统级别的复制工具将数据库的文件直接复制到其他存储设备上,实现备份目的。
这种备份方法适用于非常大的数据库,因为它可以减少备份和恢复所需的时间。
3. 备份方法:使用虚拟机快照进行备份。
描述:如果数据库运行在虚拟机上,可以使用虚拟机快照功能来创建数据库的备份。
快照是虚拟机当前状态的拷贝,可以在需要的时候还原到该状态。
4. 备份方法:使用存储级别的快照功能进行备份。
描述:一些存储设备提供了快照功能,可以在存储级别对数据库进行备份。
这种备份方法通常能够在不影响数据库性能的情况下实现备份,而且可以实现非常快速的恢复。
5. 备份方法:使用第三方备份工具进行备份。
描述:市面上有许多第三方备份工具,可以根据实际需求选择适合自己数据库的备份工具。
这些备份工具通常提供更加灵活和高级的备份和恢复功能。
6. 恢复方法:使用数据库管理系统自带的恢复工具进行数据库的还原。
描述:数据库管理系统自带的恢复工具可以将备份文件中的数据和结构导入到数据库中,还原成原来的状态。
7. 恢复方法:使用事务日志进行数据库的恢复。
描述:数据库管理系统中的事务日志记录了数据库的变更历史,可以利用事务日志进行数据库的恢复,还原到数据库崩溃前的状态。
8. 恢复方法:使用数据库管理系统提供的点对点恢复工具进行数据库的恢复。
描述:一些数据库管理系统提供了特殊的恢复工具,可以直接从备份文件中进行点对点恢复,即将备份数据直接还原到生产环境中。
sqlserver数据库的备份与恢复sql实现
sqlserver数据库的备份与恢复sql实现sqlserver数据库的备份与恢复sql实现利用T-SQL语句,实现数据库的备份与还原的功能体现了SQL Server中的四个知识点:1.获取SQL Server服务器上的默认目录2.备份SQL语句的使用3.恢复SQL语句的使用,同时考虑了强制恢复时关闭其他用户进程的处理4.作业创建SQL语句的使用/*1.--得到数据库的文件目录@dbname 指定要取得目录的数据库名如果指定的数据不存在,返回安装SQL时设置的默认数据目录如果指定NULL,则返回默认的SQL备份目录名*//*--调用示例select 数据库文件目录=dbo.f_getdbpath('tempdb'),[默认SQL SERVER数据目录]=dbo.f_getdbpath(''),[默认SQL SERVER备份目录]=dbo.f_getdbpath(null)--*/if exists (select * from dbo.sysobjects where id =object_id(N'[dbo].[f_getdbpath]') and xtype in (N'FN', N'IF', N'TF')) drop function [dbo].[f_getdbpath]GOcreate function f_getdbpath(@dbname sysname)returns nvarchar(260)assqlserver数据库的备份与恢复sql实现begindeclare @re nvarchar(260)if @dbname is null or db_id(@dbname) is nullselect @re=rtrim(reverse(filename)) from master..sysdatabases where name='master' elseselect @re=rtrim(reverse(filename)) from master..sysdatabases where name=@dbnameif @dbname is nullset @re=reverse(substring(@re,charindex('/',@re)+5,260))+'BACKUP' elseset @re=reverse(substring(@re,charindex('/',@re),260))return(@re)endgo/*2.--备份数据库*//*--调用示例--备份当前数据库exec p_backupdb @bkpath='c:/',@bkfname='db_/DATE/_db.bak'--差异备份当前数据库exec p_backupdb@bkpath='c:/',@bkfname='db_/DATE/_df.bak',@bktype='DF' --备份当前数据库日志exec p_backupdb@bkpath='c:/',@bkfname='db_/DATE/_log.bak',@bktype='LOG' --*/if exists (select * from dbo.sysobjects where id =object_id(N'[dbo].[p_backupdb]') and __(id, N'IsProcedure') = 1) sqlserver数据库的备份与恢复sql实现drop procedure [dbo].[p_backupdb]GOcreate 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 --追加/覆盖备份文件asdeclare @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,getdate(),108),':',''))set @sql='backup '+case @bktype when 'LOG' then 'log ' else'database ' end +@dbname+' to disk='''+@bkpath+@bkfname+''' with '+case @bktype when 'DF' then '__NTIAL,' else '' end+case @appendfile when 1 then 'NOINIT' else 'INIT' endprint @sqlexec(@sql)go/*3.--恢复数据库sqlserver数据库的备份与恢复sql实现/*--调用示例--完整恢复数据库exec p_RestoreDb @bkfile='c:/db_2022年1015_db.bak',@dbname='db'--差异备份恢复exec p_RestoreDb@bkfile='c:/db_2022年1015_db.bak',@dbname='db',@retype='DBNOR'exec p_backupdb @bkfile='c:/db_2022年1015_df.bak',@dbname='db',@retype='DF'--日志备份恢复exec p_RestoreDb@bkfile='c:/db_2022年1015_db.bak',@dbname='db',@retype='DBNOR'exec p_backupdb @bkfile='c:/db_2022年1015_log.bak',@dbname='db',@retype='LOG'--*/if exists (select * from dbo.sysobjects where id =object_id(N'[dbo].[p_RestoreDb]') and __(id, N'IsProcedure') = 1) drop procedure [dbo].[p_RestoreDb]create proc p_RestoreDb@bkfile nvarchar(1000), --定义要恢复的备份文件名@dbname sysname='', --定义恢复后的数据库名,默认为备份的文件名@dbpath nvarchar(260)='', --恢复后的数据库存放目录,不指定则为SQL的默认数据目录@retype nvarchar(10)='DB', --恢复类型:'DB'完事恢复数据库,'DBNOR' 为差异恢复,日志恢复进行完整恢复,'DF' 差异备份的恢复,'LOG' 日志恢复@filenumber int=1, --恢复的文件号@overexist bit=1, --是否覆盖已经存在的数据库,仅@retype为@killuser bit=1 --是否关闭用户使用进程,仅@overexist=1时有效asdeclare @sql varchar(8000)sqlserver数据库的备份与恢复sql实现--得到恢复后的数据库名if isnull(@dbname,'')=''select @sql=reverse(@bkfile),@sql=case when charindex('.',@sql)=0 then @sqlelse substring(@sql,charindex('.',@sql)+1,1000) end,@sql=case when charindex('/',@sql)=0 then @sqlelse left(@sql,charindex('/',@sql)-1) end,@dbname=reverse(@sql)--得到恢复后的数据库存放目录if isnull(@dbpath,'')='' set @dbpath=dbo.f_getdbpath('')--生成数据库恢复语句set @sql='restore '+case @retype when 'LOG' then 'log ' else'database ' end+@dbname +' from disk='''+@bkfile+''''+' with file='+cast(@filenumber as varchar)+case when @overexist=1 and @retype in('DB','DBNOR') then',replace' else '' end +case @retype when 'DBNOR' then ',__ERY' else ',__Y' end print @sql--添加移动逻辑文件的处理if @retype='DB' or @retype='DBNOR'begin--从备份文件中获取逻辑文件名declare @lfn nvarchar(128),@tp char(1),@i int--创建临时表,保存获取的信息create table #tb(ln nvarchar(128),pn nvarchar(260),tp char(1),fgn nvarchar(128),sz numeric(20,0),Msz numeric(20,0))--从备份文件中获取信息insert into #tb exec('restore filelistonly from disk='''+@bkfile+'''')declare #f cursor for select ln,tp from #tbopen #fsqlserver数据库的备份与恢复sql实现set @i=0while @@fetch_status=0beginselect @sql=@sql+',move '''+@lfn+''' to'''+@dbpath+@dbname+cast(@i as varchar) +case @tp when 'D' then '.mdf''' else '.ldf''' end,@i=@i+1fetch next from #f into @lfn,@tpendclose #fdeallocate #fend--关闭用户进程处理if @overexist=1 and @killuser=1begindeclare @spid varchar(20)declare #spid cursor forselect spid=cast(spid as varchar(20)) from master..sysprocesses where dbid=db_id(@dbname)open #spidwhile @@fetch_status=0beginexec('kill '+@spid)fetch next from #spid into @spidendclose #spiddeallocate #spidend--恢复数据库exec(@sql)gosqlserver数据库的备份与恢复sql实现/*4.--创建作业*//*--调用示例--每月执行的作业exec p_createjob @jobname='mm',@sql='select * from syscolumns',@freqtype='month'--每周执行的作业exec p_createjob @jobname='ww',@sql='select * from syscolumns',@freqtype='week'--每日执行的作业exec p_createjob @jobname='a',@sql='select * from syscolumns'--每日执行的作业,每天隔4小时重复的作业exec p_createjob @jobname='b',@sql='select * fromsyscolumns',@fsinterval=4--*/if exists (select * from dbo.sysobjects where id =object_id(N'[dbo].[p_createjob]') and __(id, N'IsProcedure') = 1) drop procedure [dbo].[p_createjob]GOcreate proc p_createjob@jobname varchar(100), --作业名称@sql varchar(8000), --要执行的命令@dbname sysname='', --默认为当前的数据库名@freqtype varchar(6)='day', --时间周期,month 月,week 周,day 日@fsinterval int=1, --相对于每日的重复次数@time int=__ --开始执行时间,对于重复执行的作业,将从0点到23:59分asif isnull(@dbname,'')='' set @dbname=db_name()sqlserver数据库的备份与恢复sql实现--创建作业exec msdb..sp_add_job @job_name=@jobname--创建作业步骤exec msdb..sp_add_jobstep @job_name=@jobname,@step_name = '数据处理',@subsystem = 'TSQL',@database_name=@dbname,@command = @sql,@retry_attempts = 5, --重试次数@retry_interval = 5 --重试间隔--创建调度declare @ftype int,@fstype int,@ffactor intselect @ftype=case @freqtype when 'day' then 4when 'week' then 8when 'month' then 16 end,@fstype=case @fsinterval when 1 then 0 else 8 endif @fsinterval1 set @time=0set @ffactor=case @freqtype when 'day' then 0 else 1 end EXEC msdb..sp_add_jobschedule @job_name=@jobname, @name = '时间安排',@freq_type=@ftype , --每天,8 每周,16 每月@freq_interval=1, --重复执行次数@freq_subday_type=@fstype, --是否重复执行@freq_subday_interval=@fsinterval, --重复周期@freq_recurrence_factor=@ffactor,@active_start_time=@time --下午17:00:00分执行go/*--应用案例--备份方案:sqlserver数据库的备份与恢复sql实现完整备份(每个星期天一次)+差异备份(每天备份一次)+日志备份(每2小时备份一次)调用上面的存储过程来实现--*/declare @sql varchar(8000)--完整备份(每个星期天一次)set @sql='exec p_backupdb @dbname=''要备份的数据库名'''exec p_createjob @jobname='每周备份',@sql,@freqtype='week'--差异备份(每天备份一次)set @sql='exec p_backupdb @dbname=''要备份的数据库名'',@bktype='DF'' exec p_createjob @jobname='每天差异备份',@sql,@freqtype='day'--日志备份(每2小时备份一次)set @sql='exec p_backupdb @dbname=''要备份的数据库名'',@bktype='LOG''exec p_createjob @jobname='每2小时日志备份',@sql,@freqtype='day',@fsinterval=2/*--应用案例2生产数据核心库:__备份方案如下:1.设置三个作业,分别对__库进行每日备份,每周备份,每月备份2.新建三个新库,分别命名为:每日备份,每周备份,每月备份3.建立三个作业,分别把三个备份库还原到以上的三个新库。
Microsoft SQL Server 还原数据库操作步骤的详细解析
还原数据库---Microsoft SQL Server还原数据库操作详细步骤企业管理器--右键"数据库"--所有任务--还原数据库--"还原为数据库库"中输入还原后的数据库名--还原选择"从设备"--选择设备--添加--添加你的备份文件--确定,回到数据库还原的界面--备份号--选择内容--选择你要恢复那次备份的内容--选项--将"移至物理文件名"中的物理文件名修改为你的数据文件要存放的文件名--如果要还原的数据库已经存在,选择"在现有数据库上qz还原"--确定--或用SQL语句:restore database 数据库 from disk='c:\你的备份文件名'还原数据库企业管理器中的操作:1.进行完整恢复企业管理器--右键"数据库"--所有任务--还原数据库--"还原为数据库库"中输入还原后的数据库名,设为:test--还原选择"从设备"--选择设备--添加--添加你的备份文件--确定,回到数据库还原的界面--"还原备份集",选择"数据库--完全"--选项--将"移至物理文件名"中的物理文件名修改为你的数据文件要存放的文件名--如果要还原的数据库已经存在,选择"在现有数据库上qz还原"--"恢复完成状态",选择"使数据库不再运行,但能还原其它事务日志"--确定--或用SQL语句:restore database 数据库 from disk='c:\你的完全备份文件名' with norecovery2.进行差异恢复企业管理器--右键"数据库"--所有任务--还原数据库--"还原为数据库库"中选择数据库名:test--还原选择"从设备"--选择设备--添加--添加你的备份文件--确定,回到数据库还原的界面--"还原备份集",选择"数据库--差异"--"恢复完成状态",选择"使数据库不再运行,但能还原其它事务日志"--确定--或用SQL语句:restore database 数据库 from disk='c:\你的差异备份文件名' with norecovery3.进行日志恢复企业管理器--右键"数据库"--所有任务--还原数据库--"还原为数据库库"中选择数据库名:test--还原选择"从设备"--选择设备--添加--添加你的备份文件--确定,回到数据库还原的界面--"还原备份集",选择"事务日志"--"恢复完成状态",选择"使数据库可以继续运行,但无法还原其它事务日志" --确定--或用SQL语句:restore log 数据库 from disk='c:\你的日志备份文件名' with recovery--解决还原数据库目录不对的详细步骤:1.企业管理器中的方法:--右键"数据库"--所有任务--还原数据库--"还原为数据库库"中输入还原后的数据库名--还原选择"从设备"--选择设备--添加--添加你的备份文件--确定,回到数据库还原的界面--备份号--选择内容--选择你要恢复那次备份的内容--选项--将"移至物理文件名"中的物理文件名修改为你的数据文件要存放的文件名--如果要还原的数据库已经存在,选择"在现有数据库上qz还原"--确定2.用SQL语句的方法(假设你的备份文件名为: c:\xx.bak--列出备份文件中的逻辑文件名restore filelistonly from disk='c:\xx.bak'--用语句恢复,根据上面列出的逻辑文件名使用move选项restore database 恢复后的数据库名from disk='c:\xx.bak'with move '逻辑数据文件名1' to 'c:\物理数据文件名1',move '逻辑数据文件名2' to 'c:\物理数据文件名2'...,move '逻辑数据文件名n' to 'c:\物理数据文件名n'没有什么要特别注意的,和企业版之间的备份/还原要注意的东西一样:1.要注意备份时的设置问题,不要指定多个备份文件,否则还原时也要指定多个备份文件2.要注意备份的媒体处理方式问题,用重写,而不是追加,否则还原的时候要指定备份号3.要注意备份的方式,用完全备份,而不是其他备份方式,否则还原时还要其他备份文件支持。
sql server数据库备份和还原作业
一、导言数据库备份和还原作为数据库管理的基本操作,对于保障数据的完整性和安全性具有重要意义。
在SQL Server数据库管理中,备份和还原操作是至关重要的,本文将围绕SQL Server数据库备份和还原作业展开详细讨论。
二、SQL Server数据库备份作业1.1 确定备份策略在进行SQL Server数据库备份作业之前,首先需要确定备份策略,包括全备份、差异备份和日志备份等。
根据业务需求和数据重要性制定合理的备份策略,保证数据可靠性和恢复性。
1.2 创建备份作业使用SQL Server Management Studio或Transact-SQL语句创建数据库备份作业,设置备份类型、备份频率、备份路径等关键参数,保证备份作业的有效性和稳定性。
1.3 监控和日志记录在备份作业运行过程中,需要监控备份作业的执行情况,记录备份日志并及时处理备份错误和异常,保证备份数据的完整性和可用性。
三、SQL Server数据库还原作业2.1 确认还原需求在进行SQL Server数据库还原作业之前,需要明确还原的需求,包括完整性检查、数据恢复点、还原目标等关键信息,为还原操作做好充分准备。
2.2 创建还原作业使用SQL Server Management Studio或Transact-SQL语句创建数据库还原作业,设置还原方式、还原路径、还原选项等关键参数,保证还原作业的顺利进行。
2.3 验证还原结果在还原作业完成后,需要对还原的数据进行完整性验证和业务应用测试,确保数据的完整性和可用性,保证还原操作的成功性。
四、SQL Server数据库备份和还原的最佳实践3.1 定期备份和监控建立定期的数据库备份作业,监控备份的执行情况,及时处理备份失败和异常,保证数据库备份的及时性和可靠性。
3.2 多备份路径和定期恢复测试使用多备份路径进行数据库备份,确保备份数据的安全性,定期进行数据库的恢复测试,验证数据库备份的可恢复性。
SQLServer数据库备份和还原
SQLServer数据库备份和还原⼀、SQL命令备份BACKUP DATABASE TestDb TO DISK='d:\TestDb.bak'还原RESTORE DATABASE TestDb FROM DISK='d:\TestDb.bak'⼆、使⽤管理⼯具三、使⽤sqlcmd备份sqlcmd -S . -E -Q "BACKUP DATABASE AbpFirst TO DISK='d:\AbpFirst.bak'"还原sqlcmd -S . -E -Q "RESTORE DATABASE AbpFirst FROM DISK='d:\AbpFirst.bak'"四、常见问题1.还原失败原因:Sql server还原失败,提⽰:数据库正在使⽤,⽆法获得对数据库的独占访问权解决⽅案1.如果你使⽤管理⼯具还原数据库并且在Microsoft SQL Server Management Studio 2016或以上版本的话,可以在还原的时候勾选"关闭到⽬标数据库的现有链接"解决⽅案2:如果你的SqlServer Management Studio的版本⽐较低,可以设置数据库为单⽤户模式,执⾏完还原操作后,恢复为多⽤户模式设置⽅式:选中要还原的数据库-->属性-->选项-->限制访问该值从MULTI_USER修改为SINGLE_USER,此时该数据库就会显⽰为单⽤户模式这是GUI的模式,语句的办法⽐较简单---设置数据库为单⽤户模式USE MASTERGOALTER DATABASE eol_tcgroup SET SINGLE_USER WITH ROLLBACK IMMEDIATE;GO---设置数据库为多⽤户模式USE MASTERGOALTER DATABASE eol_tcgroup SET MULTI_USER WITH ROLLBACK IMMEDIATE;GO解决⽅案3:完全使⽤T-Sql的⽅式,执⾏备份数据库操作use mastergo---声明变量declare@dbName nvarchar(max)='Mvc_HNHZ';declare@dbFullName nvarchar(max)='E:\NewWork\Web\backup\test1.bak';--1.1修改为单⽤模式exec(N'ALTER DATABASE '+@dbName+' SET SINGLE_USER WITH ROLLBACK IMMEDIATE');--1.2结束链接进程DECLARE@kid varchar(max)SET@kid=''SELECT@kid=@kid+'KILL '+CAST(spid as Varchar(10)) FROM master..sysprocesses WHERE dbid=DB_ID(@dbName) ;EXEC(@kid) ;--2.执⾏还原语句restore database@dbName from disk=@dbFullNamewith replace--覆盖现有的数据库--3.重置数据库为多⽤户模式exec(N'ALTER DATABASE '+@dbName+' SET MULTI_USER WITH ROLLBACK IMMEDIATE');2.强制断开数据库已有连接USE masterGOALTER DATABASE[DBName]SET SINGLE_USER WITH ROLLBACK IMMEDIATEGO--查看是否还有⽤户连接SELECT*FROM sys.[sysprocesses]WHERE DB_NAME([dbid])='DBName'GOALTER DATABASE[DBName]SET MULTI_USERGO其他相关⽂章:。
SQLServer定时、实时备份恢复的方法
SQLServer定时、实时备份/恢复的方法(一)使用TSql代码自动备份在SQL Server中出于数据安全的考虑,所以需要定期的备份数据库。
而备份数据库一般又是在凌晨时间基本没有数据库操作的时候进行,所以我们不可能要求管理员每天守到晚上1点去备份数据库。
要实现数据库的定时自动备份,最常用的方式就是使用SQL Server代理中的作业。
(1)启动SQL Server Agent服务(确保SQL Server Agent服务以经启动)。
(2)在SSMS的对象资源管理中“SqlServer 管理”节点下面选择作业。
然后在其中新建作业(3)为作业添加1个备份步骤,类型是T-SQL脚本,然后在命令中输入如下SQL 语句,该语句实现了对数据库TestDB1的完整备份,备份文件在C盘Backup文件夹中,文件名就是TestDB1+当时备份的日期字符串.bak。
(4)创建好步骤以后,接下来就是创建计划。
创建计划比较简单,按照你的需求选择执行周期和时间间隔,按照创建计划页面来设置就行(二)界面操作自动备份使用SQL作业中执行SQL脚本进行备份的方法虽然已经很简单了,但是至少还是要去写BACKUP脚本,这点有些人觉得不爽,那有没有更简单,更懒的方法来实现数据库的自动定时备份呢?有,那就是“维护计划”。
“维护计划”是在SSMS的对象资源管理中“管理”节点下面。
使用维护计划可以通过可视化的操作,只点点鼠标就可以创建数据库维护的SSIS包,然后仍然是通过SQL Server作业的方式来运行。
维护计划与前面说到的备份方法本质的不同就是:维护计划是SSIS包,上面的是T-SQL脚本。
假设我们现在有一个生产系统的数据库需要进行备份,由于数据库中的数据很多,数据文件很大,如果每次都进行完整备份那么硬盘占用了很大空间,而且备份时间很长,维护起来也很麻烦。
对此我们可以采用完整备份+差异备份的方式,每周日进行一次完整备份,每天晚上进行一次差异备份。
SQL数据库备份与还原的方法(图文教程)
基于MS SQL Server的数据库备份和还原目录一、MS SQL-Server 数据库简介 (2)二、MS SQL Server的安装 (2)三、MS SQL Server的数据库备份 (5)四、MS SQL Server的数据库还原 (8)五、MS SQL Server的数据库自动备份 (12)六、常见问题及解决方法 (16)1、SQL Server的密码更改 (16)2、SQL Server的身份验证方式更改 (17)七、附录......................................................................................................... 错误!未定义书签。
1、苏亚星软件系统对应的数据库文件名称....................................... 错误!未定义书签。
2、苏亚星公司简介............................................................................... 错误!未定义书签。
一、MS SQL-Server 数据库简介目前市场上数据库的主流厂商及产品有IBM DB2、Microsoft SQL SERVER 2000 、ORACLE 9i、Sybase。
SQL Server作为微软在Windows 系列平台上开发的数据库,一经推出就以其易用性得到了很多用户的青睐。
区别于FoxPro、Access小型数据库,SQL Server是一个功能完备的数据库管理系统。
它包括支持开发的引擎、标准的SQL语言、扩展的特性(如复制、OLAP、分析)等功能。
而像存储过程、触发器等特性,也是大型数据库才拥有的。
SQL SERVER 2000的优点:使用相对简单,上手容易;兼容性良好,能与微软的服务器软件紧密结合;在SQL Server 7.0的基础上对性能、可靠性、质量以及易用性进行了扩展;数据仓库。
sql server数据备份方法
sql server数据备份方法SQL Server数据备份可以通过以下方法进行:1. 使用SQL Server Management Studio (SSMS):打开SSMS并连接到相应的SQL Server实例。
在对象资源管理器中,找到并右键点击数据库,然后选择“任务” -> “备份”。
在“备份类型”中选择全备份或差异备份,然后选择目标位置和文件名。
点击“确定”开始备份。
2. 使用命令行工具:打开命令提示符或PowerShell。
使用`BACKUP DATABASE`命令来备份数据库,例如:`BACKUP DATABASE [YourDatabaseName] TO DISK = 'D:\Backups\'`。
3. 使用第三方工具: 有许多第三方工具,如ApexSQL、Redgate SQL Backup等,可以帮助您备份SQL Server数据库。
4. 备份事务日志: 如果您希望备份事务日志,可以使用`BACKUP LOG`命令。
这可以帮助您在发生故障时进行点时间恢复。
5. 自动备份: 使用SQL Server Agent可以设置自动备份作业,定期备份您的数据库。
6. 差异备份和日志备份: 根据需要选择不同的备份类型,例如差异备份和日志备份,以更有效地管理您的备份策略。
7. 完全恢复模型: 如果您的数据库使用完全恢复模型,您可以使用日志备份和差异备份来还原数据。
8. 物理文件备份: 如果您需要更底层的备份,可以备份数据库的物理文件(例如MDF和LDF文件)。
9. 使用云服务: 使用云服务提供商(如Azure和Amazon Web Services)提供的数据库服务,它们通常提供自动备份和恢复功能。
10. 定期验证备份: 确保定期测试备份文件的有效性,确保在需要时可以成功恢复数据。
在进行数据备份之前,请确保已经进行了完整的数据库备份,并保存好这些备份文件,以防止数据丢失。
在sql server中迁移数据的几种方法
在sql server中迁移数据的几种方法在SQL Server中迁移数据有多种方法,包括备份和还原、复制和复制、SQL Server Integration Services(SSIS)等。
下面将详细介绍每种方法。
1.备份和还原:备份和还原是一种常用的数据迁移方法。
它通过将源数据库的备份文件转移到目标服务器,然后使用还原操作将备份文件恢复到目标数据库中。
这种方法适用于小型数据库的迁移,它简单而且效率较高。
但是,由于备份和还原是整个数据库级别的迁移方法,所以在迁移大型数据库时可能需要一段时间来进行备份和还原操作,因此不适合快速迁移大量数据的场景。
2.复制和复制:复制和复制是一种常用的数据迁移方法,适用于需要实时或定期将数据从一个数据库复制到另一个数据库的场景。
它通过在源数据库和目标数据库之间建立一个复制链来实现数据的迁移。
复制和复制可以使用SQL Server自带的事务复制(transactional replication)或快照复制(snapshot replication)来进行数据迁移。
事务复制是一种持续复制的方法,可以保持源数据库和目标数据库之间的数据同步。
快照复制则是一种定期复制的方法,每次复制都会生成一个目标数据库的快照。
根据数据迁移的需求,可以选择适用的复制方法。
3. SQL Server Integration Services(SSIS):SQL Server Integration Services(SSIS)是SQL Server中的一种强大的ETL(Extract, Transform, Load)工具。
它可以帮助用户进行复杂的数据迁移和转换操作。
SSIS具有丰富的数据流转换和任务控件,可以从多个数据源抽取数据,进行不同的转换操作,然后将数据加载到目标数据库中。
SSIS可以通过可视化的设计界面来创建数据迁移的工作流程,也可以使用SSIS的脚本任务来编写自定义的数据迁移逻辑。
SQL server 数据库的备份与恢复
第12章数据库的备份与恢复本章内容12.1 数据库的备份12.2 数据库的恢复12.1 数据库的备份12.1.1 数据库备份概述12.1.2 创建和删除备份设备12.1.3 备份数据库12.1.1 数据库备份概述⏹备份是对SQL Server数据库或事务日志进行的复制,数据库备份记录了在进行备份操作时数据库中所有数据的状态,如果数据库因意外而损坏,这些备份文件将在数据库恢复时被用来恢复数据库。
1. 备份内容数据库需备份的内容可分为:⏹系统数据库主要包括master、msdb和model数据库,它们记录了重要的系统信息,是确保系统正常运行的重要依据,必须完全备份。
⏹用户数据库是存储用户数据的存储空间集,通常用户数据库中的数据依其重要性可分为关键数据和非关键数据。
对于关键数据则是用户的重要数据,不易甚至不能重新创建,必须进行完全备份。
⏹事务日志记录了用户对数据的各种操作,平时系统会自动管理和维护所有的数据库事务日志。
相对于数据库备份,事务日志备份所需要的时间较少,但恢复需要的时间比较长。
2. 备份设备⏹备份设备是用来存储数据库、事务日志或文件和文件组备份的存储介质。
备份设备可以是硬盘、磁带或命名管道(逻辑通道)。
⏹本地主机硬盘和远程主机的硬盘可作为备份设备,备份设备在硬盘中是以文件的方式存储的。
⏹SQL Server使用物理设备名称或逻辑设备名称来标识备份设备。
☐物理备份设备是操作系统用来标识备份设备的名称。
这类备份设备称为临时备份设备,其名称没有记录在系统设备表中,只能使用一次。
☐逻辑备份设备是用来标识物理备份设备的别名或公用名称,以简化物理设备的名称。
这类备份设备称为永久备份设备,其名称永久地存储在系统表中,可以多次使用。
3. 备份频率⏹数据库备份频率一般取决于修改数据库的频繁程度以及一旦出现意外,丢失的工作量的大小,还有发生意外丢失数据的可能性大小。
⏹在正常使用阶段,对系统数据库的修改不会十分频繁,所以对系统数据库的备份也不需要十分频繁,只要在执行某些语句或存储过程导致SQL Server对系统数据库进行了修改的时候备份。
SQL Server数据库-备份与恢复
第8章 备份与恢复——备份和恢复概述01数据库备份概念1.备份内容2.由谁做备份3.备份介质4.何时备份5.限制的操作6.备份方法1.备份内容数据库中数据的重要程度决定了数据恢复的必要性与重要性,也就决定了数据是否及如何备份。
数据库需备份的内容可分为数据文件(包括主要数据文件和次要数据文件)、日志文件两部分。
其中,数据文件中所存储的系统数据库是确保SQL Server 2016系统正常运行的重要依据,无疑,系统数据库必须完全备份。
2.由谁做备份在SQL Server 2016中,具有下列角色的成员可以做备份操作:(1)固定的服务器角色sysadmin(系统管理员)。
(2)固定的数据库角色db_owner(数据库所有者)。
(3)固定的数据库角色db_backupoperator(允许进行数据库备份的用户)。
备份介质是指将数据库备份到的目标载体,即备份到何处。
SQL Server 2016中,允许使用两种类型的备份介质。
(1)硬盘:最常用的备份介质,可以用于备份本地文件,也可以用于备份网络文件。
(2)磁带:大容量的备份介质,磁带仅可用于备份本地文件。
对于系统数据库和用户数据库,其备份时机是不同的。
(1)系统数据库。
当系统数据库master、msdb和model中的任何一个被修改以后,都要将其备份。
master数据库包含了SQL Server 2016系统有关数据库的全部信息,即它是“数据库的数据库”。
如果master数据库损坏,那么SQL Server 2016可能无法启动,并且用户数据库可能无效。
当master数据库被破坏而没有master数据库的备份时,就只能重建全部的系统数据库。
当修改了系统数据库msdb或model时,也必须对它们进行备份,以便在系统出现故障时恢复作业以及用户创建的数据库信息。
(2)用户数据库。
当创建数据库或加载数据库时,应备份数据库;当为数据库创建索引时,应备份数据库,以便恢复时能够大大节省时间。
SQLServer数据库的备份和还原详解
SQLServer数据库的备份和还原详解1. 基本概念:mdf文件:SqlServer数据库的主数据文件ldf文件:SqlServer数据库的日志文件SQL Server管理的每个数据库都对应一个mdf文件和一个ldf文件。
当SQL Server服务处于开启时,这些文件是无法删除的。
用SQL Server 企业管理器,单击某个数据库,选择右键菜单中的“属性",从弹出对话框的“数据文件”和“事务日志”标签页中可以查看这个数据库对应的mdf文件路径和ldf文件路径。
2. 用SQL Server 企业管理器备份和还原数据库:例如,备份数据库到可移动存储介质,然后还原到另一台机器上,步骤如下:备份:单击要备份的数据库,从右键菜单选择“所有任务->备份数据库”。
选择“完全备份”,删除“备份到”列表框中的现有内容,然后“添加”;弹出“选择备份目的”对话框,“文件名”就是你要得到的备份文件的存放路径。
选好后确定,这时“备份到”列表框中出现你选择的目的文件路径。
因为没有重名文件,“追加”或“重写”选项的效果是一样的,不用管。
选中它,确定,等待备份完成。
完成后在你指定的路径下将看到你备份的文件,注意该文件默认没有后缀名。
备份文件还有很大的压缩空间,一般一个40多M的备份文件用winRAR压缩后只有4M左右,作为邮箱附件也没有问题。
还原:将备份文件放到一个便于管理的文件夹下,例如你的数据库叫“test”,可以建立一个叫“e:\db_bak\test\”的文件夹。
从SQL Server 企业管理器单击“数据库”,选择“新建数据库...”,起名“test”,确定。
看到该数据库出现在数据库列表中,里面只有一些系统tables。
注意新建数据库默认的mdf文件和ldf文件都会被放在SQL Server安装目录下的子目录“MSSQL\data\”中,文件名与数据库名称相同。
单击该数据库,从右键列表中选择“所有任务->还原数据库”。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
远程备份SQL SERVER数据库
我们使用本地的SQL 企业管理器来实现远程备份SQL SERVER数据库。
步骤如下:1,首先打开企业管理器-------展开MICROSOFT SQL SERVERS------在SQL SERVER组上右键-------选择“新建SQL SERVER 注册”如图所示:
2,打开向导后点击下一步,进入添加服务器,在可用的服务器里输入你要远程备份数据库的服务器IP ,点击添加以后,在添加的服务器栏目里就会出现刚才你所添加的服务器IP。
点击下一步。
如图所示:
3,在这一步,选择第二项,使用SQL 身份验证。
如图所示:
4,输入正确的SQL 管理员帐号和密码,点击确定以后,就将远程的服务器SQL数据库显示在本地了!如图所示:
5,展开远程服务器的数据库。
按照下图所示,就可以在本地进行远程SQL SERVER的数据库备份了。
===============================================
说明:
一、当我们真正使用SQL SERVER的超级用户进行远程备份数据库的时候,我们就能感受到这个帐号不仅带来了方便,更给服务器安全带来了不可忽视的威胁,所以这个帐号一定要和系统管理员密码那样设置的够复杂!
二、经我个人测试,发现无法用SQL SERVER 2000 来远程链接 SQL SERVER 2005.
三、以上测试均在:WINDOWS 2003 SQL SERVER2000下测试成功!
SQL Server 2000 数据库还原备份文件
1、打开Sql server 2000数据库,在数据库标签上有右键选择-》所有任务-》还原数据库
2、弹出还原数据库对话框
(1)在“常规”选项卡中的“还原为数据库(R):”后面的文本框中填写要还原后数据库的名称
(2)在“常规”选项卡中的“还原”后面的单选按钮中选择“从设备(M)”(3)在“常规”选项卡中的“参数”的“设备(V)”中点击按钮“选择设备”(4)在弹出的对话框中选择“文件名(F)”的单选按钮,在下面的选择框中选择需要还原的文件
(5)点击确定
3、点击“选择”选项卡
(1)将“在现有数据库上强制还原”选择√
(2)在下面“将数据库文件还原为(S):”下面的“逻辑文件名称”不用修改,
“移至物理文件名”是真正的存在路径,需要计算机上真实的存在
例如:D:\123\123\123.mdf D:\123\123\123. ldf
D:\123\123\ 是备份时候的路径,还原的机器上有可能不存在,所以要将路径修改为机器上的真实存在路径
(3)点击确定
MySQL ODBC进行MySQL和SQL Server转换
将MySQL数据库转换为SQL Server的数据库,或者将SQL Server数据库转换为MySQL的数据库,在NT环境下很多时候都会用到。
使用MySQL ODBC后就比较好办,可以使用SQL Server7的管理工具,也可以使用MySQL的管理工具,更可以使用其它方的管理工具。
这里介绍一个使用SQL7的MMC的方法,将SQL Server7的数据转化为MySQL的数据库,将源和目的反之,就可以将MySQL的数据库转化为SQL Server7的数据库。
1.安装MySQL的ODBC接口。
2.建立MySQL的DSN,可以建系统DSN,这里命名testMySQL,填写IP,dababase,用户名口令等项,完成。
3.在SQL7的MMC中,选择要导出的数据库,右键选择All Tasks->Export Datas。
4.开始DTS Export Wizerd:
Choose a Data Source:Microsoft OLE DB Privoder for SQL Server server:你的SQL Server7数据库的服务器
是否使用NT认证和用户名口令看你自己的了。
最后选择一个Database,如:mynews(你自己要导到MySQL中的数据库)。
5.Choose a Destination:选MySQL:
User/System DSN,如果建立过就选择,如果没有建立就新建。
6.Specify Table Copy or Query:
Copy table(s) from the source database,从源数据库拷贝表开始
7.Select Source Table:
选择要拷贝的表,如果不想仔细调整,就选择全部吧。
8.Run immediately,当然要立即执行,下一步再选完成,就开始转换。
这个转换有时一部分表可能要失败,双击失败的表格,看看什么原因,一般是SQL7的数据类型问题,作一些小的修改就应该可以了。