首页数据库sqlserver数据库实时备份(如何实现sql server实时备份数据库)

sqlserver数据库实时备份(如何实现sql server实时备份数据库)

编程之家2023-10-1987次浏览

大家好,今天小编来为大家解答以下的问题,关于sqlserver数据库实时备份,如何实现sql server实时备份数据库这个很多人还不知道,现在让我们一起来看看吧!

sqlserver数据库实时备份(如何实现sql server实时备份数据库)

如何实现sql server实时备份数据库

可以利用数据库复制技术来实现数据同步更新。SQL复制的基本元素包括出版服务器、订阅服务器、分发服务器、出版物和文章。 SQL SERVER主要采用出版物、订阅的方式来处理复制。源数据所在的服务器是出版服务器,负责发表数据。出版服务器把要发表的数据的所有改变情况的拷贝复制到分发服务器,分发服务器包含有一个分发数据库,可接收数据的所有改变,并保存这些改变,再把这些改变分发给订阅服务器。

主要有以下几个步骤:

1、配置出版服务器:

(1)选中指定[服务器]节点;

(2)从[工具]下拉菜单的[复制]子菜单中选择[发布、订阅服务器和分发]命令;

(3)系统弹出一个对话框点[下一步]然后看着提示一直操作到完成;

sqlserver数据库实时备份(如何实现sql server实时备份数据库)

(4)当完成了出版服务器的设置以后系统会为该服务器的树形结构中添加一个复制监视器。同时也生成一个分发数据库(distribution)。

2、创建出版物:

(1)选中指定的服务器;

(2)从[工具]菜单的[复制]子菜单中选择[创建和管理发布]命令;

(3)在弹出的对话框中选择要创建出版物的数据库,单击[创建发布];

(4)在[创建发布向导]的提示对话框中单击[下一步]系统就会弹出一个对话框,选择合适的复制类型;

sqlserver数据库实时备份(如何实现sql server实时备份数据库)

(5)单击[下一步]系统要求指定可以订阅该发布的数据库服务器类型,SQLSERVER允许在不同的数据库如 ORACLE或ACCESS之间进行数据复制;

(6)单击[下一步]系统就弹出一个定义文章的对话框也就是选择要出版的表;

(7)点击[下一步]直到操作完成。

3、设计订阅:

(1)选中指定的订阅服务器;

(2)从[工具]下拉菜单中选择[复制]子菜单的[请求订阅];

(3)按照单击[下一步]操作直到系统会提示检查SQL SERVER代理服务的运行状态,执行复制操作的前提条件是SQL SERVER代理服务必须已经启动;

(4)单击[完成],即可实现实时备份数据库。

如何将SQLSERVER数据库备份到网络上

最近在看联机从书,在看到sp_addumpdevice时无意间看到如下内容:

"

[@physicalname=]'physical_name'

备份设备的物理名称。物理名称必须遵照操作系统文件名称的规则或者网络设备的通用命名规则,并且必须包括完整的路径。physical_name的数据类型为 nvarchar(260),没有默认值,并且不能为 NULL。

当创建远程网络位置上的备份设备时,请确保在其下启动 SQL Server的名称对远程的计算机有适当的写入能力。

B.添加网络磁盘备份设备

下面的示例显示一个远程磁盘备份设备。在其下启动 SQL Server的名称必须对该远程文件拥有权限。

USE master

EXEC sp_addumpdevice'disk','networkdevice','\\servername\sharename\path\filename.ext'

以前曾看到过有人问,怎么样才能将数据备份到网络上,一直没有答案,然后我就试验了一把.

在服务器上建了一个目录,然后确保共享并有权限,如果需要建在共享目录下的目录下,那还得保证用户有权限

当然,SQLSERVER系统启动早于登录,一般用户会在登录中使用本地系统账户,我想在登录到系统之前一直是

administrator用户模拟,因此,我将登录的账户改为了网络用户,因为我公司有域,因此我将域用户设置为本机

的系统管理员,以确保该服务能启动.

接下来更简单了:

sp_addumpdevice'DISK','NetWork','\\server\d$\databak\xuzh.bak'

go

backup database xuzh to network

得到的结果如下:

已处理 96页,这些页属于数据库'xuzh'的文件'xuzhP01'(位于文件 2上)。

已处理 16页,这些页属于数据库'xuzh'的文件'xuzhP02'(位于文件 2上)。

已处理 16页,这些页属于数据库'xuzh'的文件'xuzhS01'(位于文件 2上)。

已处理 8页,这些页属于数据库'xuzh'的文件'xuzhS02'(位于文件 2上)。

已处理 1页,这些页属于数据库'xuzh'的文件'xuzh_Log'(位于文件 2上)。

BACKUP DATABASE操作成功地处理了 137页,花费了 0.516秒(2.161 MB/秒)。

成功完成网络备份

另外,----------------------

实例说明:

环境:win2k+sqlserver 2K+查询分析器

SQLSERVER服务实例名称:mainserver

需要备份的数据库名称: msdb

本地机器名称(Client端):david

本地用户:zf密码:123

本地域名:domain

本地提供备份需求的文件夹:e:\test

第一步:建立共享文件夹

在程序代码中调用(或者CMD窗口) net share test=e:\test

或者用NetShareAdd这个API

简要说明:

net share:是WINDOWS内部的网络命令。

作用:建立本地的共享资源,显示当前计算机的共享资源信息。

语法:参见 net share/?

第二步:建立共享信用关系

master..xp_cmdshell'net use\\david\test 123/user:domain\zf'

简要说明:

1:xp_cmdshell:是SQLSERVER的扩展存储过程。

作用,以操作系统命令行解释器的方式执行给定的命令字符串,

并以文本行方式返回任何输出。

语法:参见SQLSERVER联机帮助

2:net use:是WINDOWS内部的网络命令。

作用,将计算机与共享资源连接或断开,或者显示关于计算机

连接的信息。该命令还控制持久网络连接。

语法:参见 net use/?

第三步:备份数据库

backup database msdb to disk='\\david\test\msdb.bak'

这个不需要说明吧,语法参见SQLSERVER联机帮助

第四步:删除共享文件夹

在程序代码中调用(或者CMD窗口) net share test/delete

或者用NetShareDel这个API

结果:

已处理 1376页,这些页属于数据库'msdb'的文件'MSDBData'(位于文件 1上)。

已处理 1页,这些页属于数据库'msdb'的文件'MSDBLog'(位于文件 1上)。

BACKUP DATABASE操作成功地处理了 1377页,花费了 3.653秒(3.086 MB/秒)。

这样mainserver服务器上的msdb就备份到了david机器的E:\test\msdb.bak文件了,使用起来很简单吧?恢复数据库操作也是一样,只要将第三个步骤的语句改为'restore database msdb from disk='\\david\test\msdb.bak'就可以啦。。你看完了也可以试试呀?!(最简单的测试工具查询分析器+CMD窗口)

备注:xp_cmdshell这个扩展存储过程只能SA级别的用户调用,而且是SQLSERVER的安全隐患之一,许多DBA都喜欢将其删除或者禁用,所以开发人员使用时要倍加小心哦。

文章中的例子只是简要的说明了应如何利用扩展存储过程实现远程备份与恢复,没有涉及安全以及其他方面的考虑,希望读者在代码中自行完善。

如何备份sqlserver数据库

步骤/方法

1

假如你的空间商用的是星外虚拟主机管理系统,这种系统支持第一种备份文件的还原和导入。星外系统的数据库导入分为5个步骤,大家直接到空间商的数据库管理里面就可以看到,这里不再叙述,发个截图给大家看。

2

如果你只有数据库源文件,也就是有mdf和ldf文件。可以直接把SQLServer暂停,然后用备份的源文件覆盖现在的初始源文件,然后启动SQLServer。注意这种办法要先开通这个数据库,保持源文件名要一致,这样才能直接覆盖。

3

有一种办法就是附加数据库,把mdf和ldf文件直接附加,系统会自动生成一个数据库。下面是截图:如果你的空间商一定要第一种备份文件才能还原,可以先

通过这种附加方法把数据库生成,然后在企业管理器中导出备份文件即可。注意上面的附加为:项目要写准备还原的数据库名称。

4

用SQL网页管理器导入备份文件。这种办法需要先安装一个web界面的SQLServer管理器,类似于管理MySQL的PHPmyadmin,应该网上有下载的。下面是截图:

http://jingyan.baidu.com/article/f7ff0bfc4f14632e26bb13eb.html

关于sqlserver数据库实时备份,如何实现sql server实时备份数据库的介绍到此结束,希望对大家有所帮助。

php写入数据库,php 如何把一条sql语句写入数据库没有主机的台式电脑,没有主机的台式电脑好不