SQL Server 通常有两种备份数据库的操作方法:
通过备份命令进行
备份的命令是
Backup DataBase XXXX To Disk="c:XXX.Bak"
(其中XXXX是待备份的数据库名称)
这种备份的好处是可以将命令集成到所开发软件的内部,允许用户通过点击按钮或菜单的形式来进行,并且隔离用户和数据库本身,提高安全性。
相对应的,恢复数据库的命令是Restore database XXXXfrom disk='c:xx.bak'
2.通过SQL Server Managment Studio执行
这个是通过数据库管理器来操作,需要有数据库管理权限和Windows操作权限。
步骤如下:
选中需要备份的数据库,右键点击鼠标,选择“任务”菜单下的"备份“子菜单
备份完成后会有对话框提示备份完成,关闭对话框即可。
② 如何备份sql server数据库文件
1. 下载2014-02-10 07:16的全量备份文件并解压出要恢复的数据库备份文件。
2. 以NORECOVERY的方式还原2014-02-10 07:16的全量备份,操作SQL语句如下:
还原成功后,数据库处于Restoring状态。
3. 继续以NORECOVERY的方式还原2014-02-12
06:51的增量备份,操作SQL语句如下:
还原成功后,数据库继续处于Restoring状态。
4. 日志备份文件的下载
RDS 控制台 - 备份恢复 - 数据备份,选择需要下载的备份集,点击“下载”。
点击“复制内网地址” 或 “复制外网地址” 来获取备份的 内网 或 外网 下载地址。
日志备份的地址在 RDS 控制台 - 备份恢复 - 日志备份
获取:
5. 解压备份文件
解压备份文件前,要先下载好解压工具 rds_backup_extract
解压备份文件:
bash rds_backup_extract -f /home/mysql/backup/hins575175_xtra_20150429091224.tar.gz -C /home/mysql/data
6. 以RECOVERY(默认方式)的方式还原日志
日志还原成功后,数据库处于正常状态,这时数据库中的数据就还原到了要恢复的时间点。③ 请问用SQL语句实现对指定的数据库进行备份和还原的语句是怎么样的呢
请问,是对sqlserver库的么???
备份:
BACKUP
DATABASE
"mydb"
TO
DISK
='C:\mybak.db'
with
init
还原
use
master
RESTORE
DATABASE
"mydb"
FROM
DISK='C:\mybak.db';
use
mydb
[补充]
这两个命令都得指定一个文件名字啊..
你看我的例子都是'C:\mybak.db'
你指定了一个目录肯定不行的啊,还得要指定一个文件名字才成!!
这两个是sqlserver的自定义的存储过程,其实也能手工在sqlserver的企业管理器中看到,,
选中库,右键--所有任务--备份还原数据库那.
还不行就
给我信息吧...
这里补充我一般看不见的...④ 如何备份整个mysql数据库
1、首先打开mysql数据库软件进入软件主界面。
⑤ sql数据库备份
sp_admpdevice只是添加了一个备份设备,备份设备信息存放在数据库中,只有在执行backup database操作的时候向设备中写入备份数据后文件才会被创建。
一般备份数据库可以指定备份到设备或备份到文件,因此不一定要备份到创建的备份设备中。⑥ 如何实现sql server实时备份数据库
可以利用数据库复制技术来实现数据同步更新 。SQL复制的基本元素包括出版服务器、订阅服务器、分发服务器、出版物和文章。 SQL SERVER 主要采用出版物、订阅的方式来处理复制。源数据所在的服务器是出版服务器,负责发表数据。出版服务器把要发表的数据的所有改变情况的拷贝复制到分发服务器,分发服务器包含有一个分发数据库,可接收数据的所有改变,并保存这些改变,再把这些改变分发给订阅服务器 。
主要有以下几个步骤:
1、配置出版服务器 :
(1)选中指定[服务器]节点 ;
(2)从[工具]下拉菜单的[复制]子菜单中选择[发布、订阅服务器和分发]命令 ;
(3)系统弹出一个对话框点[下一步]然后看着提示一直操作到完成;
(4)当完成了出版服务器的设置以后系统会为该服务器的树形结构中添加一个复制监视器。同时也生成一个分发数据库(distribution) 。
2、创建出版物 :
(1)选中指定的服务器;
(2)从[工具]菜单的[复制]子菜单中选择[创建和管理发布]命令;
(3)在弹出的对话框中选择要创建出版物的数据库,单击[创建发布] ;
(4)在[创建发布向导]的提示对话框中单击[下一步]系统就会弹出一个对话框,选择合适的复制类型;
(5)单击[下一步]系统要求指定可以订阅该发布的数据库服务器类型,SQLSERVER允许在不同的数据库如 ORACLE或ACCESS之间进行数据复制;
(6)单击[下一步]系统就弹出一个定义文章的对话框也就是选择要出版的表 ;
(7)点击[下一步]直到操作完成。
3、设计订阅 :
(1)选中指定的订阅服务器;
(2)从[工具]下拉菜单中选择[复制]子菜单的[请求订阅] ;
(3)按照单击[下一步]操作直到系统会提示检查SQL SERVER代理服务的运行状态,执行复制操作的前提条件是SQL SERVER代理服务必须已经启动;
(4)单击[完成],即可实现实时备份数据库。⑦ SQL数据库备份
备份数据库
1、打开sql企业管理器,在控制台根目录中依次点开microsoft
sql
server
2、sql
server组-->双击打开你的服务器-->双击打开数据库目录
3、选择你的数据库名称(如财务数据库cwdata)-->然后点上面菜单中的工具-->选择备份数据库
4、备份选项选择完全备份,目的中的备份到如果原来有路径和名称则选中名称点删除,然后点添加,如果原来没有路径和名称则直接选择添加,接着指定路径和文件名,指定后点确定返回备份窗口,接着点确定进行备份。⑧ 数据库SQL 如何完全备份
1、点击开始菜单,打开sql企业管理器。
2、依次展开sqlserver根目录,并打开数据库。
3、选择要备份的数据库名,鼠标右键所有任务→备份数据库。
4、这里需要注意,如果之前有备份的话,一定要先删除之前的备份记录,不用担心只是删除记录而不是删除备份文件。
5、删除记录再点添加。
6、选择备份目的,就是要让你选择备份地点和备份文件命名。前面是路径后面是文件名,这个文件名是自定义的,可以根据时间或者其它来命名,如果想另存的话也可以点击另存为,然后确定。
7、添加保存路径后继续确定,然后会有备份进度提示,直到完成ok。
8、根据路径来检查是否有备份文件。⑨ 备份MYSQL数据库SQL语句怎么写
mysqlmp备份还原和mysqlmp导入导出语句大全详解
mysqlmp备份:
mysqlmp -u用户名 -p密码 -h主机数据库 a -w "sql条件" --lock-all-tables >路径
案例:
mysqlmp -uroot -p1234 -hlocalhost db1 a -w "id in (select id from b)" --lock-all-tables > c:\aa.txt
mysqlmp还原:
mysqlmp -u用户名 -p密码 -h主机数据库<路径
案例:
mysql -uroot -p1234 db1 < c:\aa.txt
mysqlmp按条件导出:
mysqlmp -u用户名 -p密码 -h主机数据库 a --where "条件语句" --no-建表>路径
mysqlmp -uroot -p1234 dbname a --where "tag='88'" --no-create-info> c:\a.sql
mysqlmp按导入:
mysqlmp -u用户名 -p密码 -h主机数据库<路径
案例:
mysql -uroot -p1234 db1 < c:\a.txt
mysqlmp导出表:
mysqlmp -u用户名 -p密码 -h主机数据库表
案例:
mysqlmp -uroot -p sqlhk9 a --no-data
讲一下 mysqlmp 的一些主要参数
--compatible=name
它告诉 mysqlmp,导出的数据将和哪种数据库或哪个旧版本的 MySQL 服务器相兼容。值可以为 ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options 等,要使用几个值,用逗号将它们隔开。当然了,它并不保证能完全兼容,而是尽量兼容。
--complete-insert,-c
导出的数据采用包含字段名的完整 INSERT 方式,也就是把所有的值都写在一行。这么做能提高插入效率,但是可能会受到 max_allowed_packet 参数的影响而导致插入失败。因此,需要谨慎使用该参数,至少我不推荐。
--default-character-set=charset
指定导出数据时采用何种字符集,如果数据表不是采用默认的 latin1 字符集的话,那么导出时必须指定该选项,否则再次导入数据后将产生乱码问题。
--disable-keys
告诉 mysqlmp 在 INSERT 语句的开头和结尾增加 /*!40000 ALTER TABLE table DISABLE KEYS */; 和 /*!40000 ALTER TABLE table ENABLE KEYS */; 语句,这能大大提高插入语句的速度,因为它是在插入完所有数据后才重建索引的。该选项只适合 MyISAM 表。
--extended-insert = true|false
默认情况下,mysqlmp 开启 --complete-insert 模式,因此不想用它的的话,就使用本选项,设定它的值为 false 即可。
--hex-blob
使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用本选项。影响到的字段类型有 BINARY、VARBINARY、BLOB。
--lock-all-tables,-x
在开始导出之前,提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭 --single-transaction 和 --lock-tables 选项。
--lock-tables
它和 --lock-all-tables 类似,不过是锁定当前导出的数据表,而不是一下子锁定全部库下的表。本选项只适用于 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 选项。
--no-create-info,-t
只导出数据,而不添加 CREATE TABLE 语句。
--no-data,-d
不导出任何数据,只导出数据库表结构。
--opt
这只是一个快捷选项,等同于同时添加 --add-drop-tables --add-locking --create-option --disable-keys --extended-insert --lock-tables --quick --set-charset 选项。本选项能让 mysqlmp 很快的导出数据,并且导出的数据能很快导回。该选项默认开启,但可以用 --skip-opt 禁用。注意,如果运行 mysqlmp 没有指定 --quick 或 --opt 选项,则会将整个结果集放在内存中。如果导出大数据库的话可能会出现问题。
--quick,-q
该选项在导出大表时很有用,它强制 mysqlmp 从服务器查询取得记录直接输出而不是取得所有记录后将它们缓存到内存中。
--routines,-R
导出存储过程以及自定义函数。
--single-transaction
该选项在导出数据之前提交一个 BEGIN SQL语句,BEGIN 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于事务表,例如 InnoDB 和 BDB。
本选项和 --lock-tables 选项是互斥的,因为 LOCK TABLES 会使任何挂起的事务隐含提交。
要想导出大表的话,应结合使用 --quick 选项。
--triggers
同时导出触发器。该选项默认启用,用 --skip-triggers 禁用它。
其他参数详情请参考手册,我通常使用以下 SQL 来备份 MyISAM 表:
/usr/local/mysql/bin/mysqlmp -uyejr -pyejr "
--default-character-set=utf8 --opt --extended-insert=false "
--triggers -R --hex-blob -x db_name > db_name.sql
使用以下 SQL 来备份 Innodb 表:
/usr/local/mysql/bin/mysqlmp -uyejr -pyejr "
--default-character-set=utf8 --opt --extended-insert=false "
--triggers -R --hex-blob --single-transaction db_name > db_name.sql
另外,如果想要实现在线备份,还可以使用 --master-data 参数来实现,如下:
/usr/local/mysql/bin/mysqlmp -uyejr -pyejr "
--default-character-set=utf8 --opt --master-data=1 "
--single-transaction --flush-logs db_name > db_name.sql
它只是在一开始的瞬间请求锁表,然后就刷新binlog了,而后在导出的文件中加入CHANGE MASTER 语句来指定当前备份的binlog位置,如果要把这个文件恢复到slave里去,就可以采用这种方法来做。
1.2 还原
用 mysqlmp 备份出来的文件是一个可以直接倒入的 SQL 脚本,有两种方法可以将数据导入。
直接用 mysql 客户端
例如:
/usr/local/mysql/bin/mysql -uyejr -pyejr db_name < db_name.sql
用 SOURCE 语法(实验不成功!!!)
其实这不是标准的 SQL 语法,而是 mysql 客户端提供的功能,例如:
SOURCE /tmp/db_name.sql;
这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户(例如 nobody)有权限读取的文件。⑩ 如何备份sql数据库
用SQL Server Management Studio连接服务器后 选择你要备份的数据库 然后 TASK -》 BACK UP -》然后按说明操作来