JAVA实现数据库备份与还原1
- 格式:pdf
- 大小:142.00 KB
- 文档页数:7
数据库管理系统的备份与恢复方法随着数据量的不断增长和重要性的提升,数据库的备份和恢复变得愈发重要。
数据库管理系统(DBMS)的备份和恢复方法不仅能够保证数据的安全性,还能够在系统发生故障或数据丢失的情况下,快速地恢复数据库的正常运行。
一、数据库备份方法1. 定期全量备份:全量备份是指将整个数据库的数据和结构进行备份,可以确保数据的完整性。
定期全量备份通常可以将备份的数据存储在独立的磁盘或远程服务器上,以防止意外的硬件故障。
2. 增量备份:增量备份是指仅备份数据库中自上次备份以来发生更改的数据。
增量备份可以大大减少备份所需的时间和存储空间。
通常,增量备份会先进行一次全量备份,然后在此基础上备份新增和更改的数据。
3. 日志备份:日志备份记录了数据库中每次修改的操作,包括事务的开始、提交和回滚等。
通过定期备份日志文件,可以实现故障恢复和数据一致性的保证。
4. 分区备份:对于大型数据库来说,分区备份是一个有效的备份方法。
可以将数据库分为多个分区,每个分区独立备份和恢复。
这样,在备份和恢复时可以大大减少所需的时间和资源。
5. 备份验证:备份完成后,建议进行备份验证,以确保备份的数据是完整和可恢复的。
验证的方法可以是通过比对备份和原始数据库中的数据行数、数据完整性和数据一致性,或者通过随机检查备份文件的内容。
二、数据库恢复方法1. 全量恢复:全量恢复是指将备份的数据库完全恢复到故障发生时的状态。
全量恢复通常需要将备份文件复制到原数据库所在的服务器上,并执行相应的恢复命令。
全量恢复会覆盖原有的数据库文件,因此在执行全量恢复前,建议先进行数据库的备份。
2. 增量恢复:增量恢复是在全量恢复的基础上,恢复数据库中自故障发生后增量备份的数据。
增量恢复需要在全量恢复之后,按照备份的顺序依次进行恢复操作。
3. 日志恢复:日志恢复是通过数据库的事务日志文件进行恢复的方法。
日志恢复可以保证数据库的一致性和完整性,可恢复到故障发生时的任何时间点。
如何进行数据库的备份和恢复第一章:数据库备份的概述数据库备份是指将数据库中的数据、索引、日志等重要信息复制到其他存储介质,以防止因误操作、硬件故障或灾害等造成数据库的损坏或丢失。
数据库备份功能成为了现代数据库管理系统中非常重要的一项功能。
本章将介绍数据库备份的概念、意义以及常见的备份策略。
第二章:选择备份方式数据库备份可以通过多种方式来实现,如逻辑备份、物理备份、增量备份等。
本章将详细介绍不同的备份方式及其应用场景,帮助读者选择最适合自己需求的备份方式。
第三章:逻辑备份逻辑备份是指备份数据库中的逻辑结构和数据,以SQL语句的形式进行备份。
逻辑备份相对于物理备份而言,备份的数据量较小且可以跨平台进行恢复,适用于数据量不大、对备份速度和恢复速度有要求的情况。
本章将介绍逻辑备份的原理和常用工具。
第四章:物理备份物理备份是指直接备份数据库底层存储结构的数据文件,可以完整地还原数据库。
物理备份相对于逻辑备份而言,备份的速度更快且占用的存储空间更小,适用于数据量较大、对备份速度和恢复速度没有严格要求的情况。
本章将介绍物理备份的原理和常用工具。
第五章:增量备份与差异备份增量备份是指只备份数据库中自上次备份以来发生变化的部分数据,可以减少备份的数据量和备份时间。
差异备份是指只备份数据库中自上次完整备份以来发生变化的部分数据,相对于增量备份而言,可以减少恢复时需要进行的合并操作。
本章将介绍增量备份和差异备份的原理、使用方法和注意事项。
第六章:备份策略与计划制定合理的备份策略和备份计划对于数据库备份的有效性至关重要。
本章将介绍备份策略的制定原则、常见的备份周期和频率,以及备份计划的编制方法。
第七章:数据库恢复技术数据库恢复是指将备份的数据库恢复到正常工作状态的过程。
本章将介绍数据库恢复的原理、常用的恢复方法和恢复工具,以及如何进行数据库的错误恢复和灾难恢复。
第八章:备份验证与测试对数据库备份进行验证和测试是确保备份的完整性和可用性的重要步骤。
基于Java的数据库备份与恢复系统设计与实现问题:基于Java的数据库备份与恢复系统设计与实现回答:1. 系统设计概述数据库备份与恢复系统是一个用于保护数据库数据完整性和可用性的关键工具。
它通过定期备份数据库,并提供恢复功能,以便在发生数据丢失或损坏的情况下能够快速恢复数据库到先前的状态。
基于Java的数据库备份与恢复系统通过结合Java编程语言和数据库管理系统的特性,实现了高效、可靠和易于使用的备份与恢复功能。
2. 系统组成和功能基于Java的数据库备份与恢复系统可以分为两个主要模块:备份模块和恢复模块。
备份模块负责定期执行数据库备份操作。
它首先与数据库管理系统进行通信,获取数据库的元数据和数据。
然后,它使用Java的文件操作功能将获取到的数据保存到指定的备份文件中。
备份模块还可以支持增量备份和差异备份,以提高备份效率和减少备份文件的大小。
此外,备份模块还可以提供备份计划的管理功能,允许用户根据自己的需求灵活地设置备份频率和存储位置。
恢复模块负责在需要恢复数据库时执行相应的恢复操作。
它首先与备份模块进行通信,获取可用的备份文件列表。
然后,用户可以选择要恢复的数据库备份文件,并指定恢复的目标位置。
恢复模块会使用Java的文件操作功能将备份文件的数据恢复到目标位置,并与数据库管理系统进行交互,更新数据库的元数据和数据,以确保数据库恢复到指定的状态。
3. 技术实现细节基于Java的数据库备份与恢复系统可以使用以下技术实现:- Java编程语言:通过使用Java编程语言,可以轻松实现与数据库管理系统的交互、文件操作和用户界面等功能。
Java的跨平台特性也使得系统可以在不同的操作系统上运行。
- 数据库管理系统API:根据所使用的数据库管理系统,可以使用相应的API 与数据库进行通信。
例如,如果使用MySQL数据库,可以使用MySQL Connector/J库来连接和操作MySQL数据库。
- 文件操作:Java提供了丰富的文件操作功能,可以通过读取和写入文件来实现数据库备份和恢复的过程。
文件备份恢复机制一、背景介绍文件备份恢复机制是计算机系统中用于保护数据安全的重要组成部分。
在现代社会中,数据的重要性越来越被人们所重视,因此及时备份和恢复数据成为了一项必要而关键的工作。
本文将详细探讨文件备份恢复机制的实现原理和Java代码实现方法。
二、文件备份机制的原理文件备份机制是指将数据从一个位置复制到另一个位置,以便在原始数据丢失或损坏时进行恢复。
在文件备份机制中,需要考虑以下几个方面:2.1 备份策略的选择备份策略是指选择何时备份文件以及备份多少份的决策。
常见的备份策略包括完整备份、增量备份和差异备份。
完整备份是将源文件的所有数据复制到备份位置,增量备份是只备份自上次备份以来修改过的文件,差异备份是只备份自上次完整备份以来被修改过的部分。
2.2 备份源和备份目标的选择备份源是指需要备份的文件或目录,可以是单个文件、整个目录,甚至是整个硬盘。
备份目标是指备份文件存放的位置,可以是本地磁盘、网络存储设备或云存储等。
2.3 备份频率的设定备份频率是指备份操作的执行间隔,根据备份策略的不同,备份频率可以是每天、每周、每月甚至更长。
2.4 备份方式的选择备份方式是指备份操作的具体实现方法。
常用的备份方式包括全量备份、增量备份和镜像备份。
三、文件恢复机制的实现文件恢复机制是指在数据丢失或损坏的情况下,通过备份数据进行恢复的方法。
文件恢复机制需要考虑以下几个方面:3.1 恢复策略的选择恢复策略是指根据实际情况选择何时进行数据恢复以及恢复的方式。
常用的恢复策略包括一致性恢复、增量恢复和差异恢复。
3.2 恢复源和恢复目标的确定恢复源是指备份文件存放的位置,恢复目标是指恢复后文件存放的位置。
3.3 恢复过程的实现恢复过程是指通过备份数据进行恢复的具体实现方法。
在文件恢复过程中,首先需要通过备份源选择要恢复的文件,然后根据备份目标将文件恢复到指定位置。
3.4 恢复结果的验证恢复结果的验证是指对恢复后的文件进行验证,确保恢复的文件与原始文件一致。
Java应用中的数据备份与恢复数据备份与恢复在任何应用系统中都是至关重要的环节,以确保数据的完整性和可靠性。
针对Java应用来说,数据备份与恢复同样具有重要性。
在本文中,将重点探讨Java应用中的数据备份与恢复的相关技术和方法。
一、数据备份数据备份是指将关键数据复制到另一位置或媒介中,以便在原始数据遭受损坏、丢失或不可恢复的情况下,能够及时恢复系统运行。
下面将介绍几种常见的数据备份方法。
1.1 定期数据库备份在Java应用中,数据库是存储关键数据的重要组成部分。
定期对数据库进行备份是非常重要的一环。
可以通过使用数据库管理工具或编写定时任务来实现定期数据库备份。
备份的频率可根据实际需求进行设定,常见的有每天、每周或每月备份一次。
1.2 离线数据快照备份除了定期数据库备份外,还可以采用离线数据快照备份的方式。
该方式通过将数据快照存储在独立的存储设备中,实现对数据的备份。
这样可以保留不同时间点的数据状态,以便在需要时进行恢复。
1.3 分布式数据备份针对大型Java应用系统,分布式数据备份是一个较为有效的备份策略。
通过将数据分散存储在多个节点上,并实时同步数据变更,可以大大提高数据备份的稳定性和可靠性。
在数据丢失或损坏时,可以从其他节点恢复数据。
二、数据恢复数据恢复是指将备份的数据重新加载到系统中,以恢复原始数据状态。
在Java应用中,数据恢复的方式取决于备份的方式。
2.1 数据库备份恢复对于定期数据库备份的情况,可以通过数据库管理工具或命令行工具恢复数据库。
通常,可以选择从最近的备份中恢复数据,并进行合并或同步操作,以保证系统的数据完整性。
2.2 离线数据快照恢复对于离线数据快照备份的情况,可以将备份时刻的数据快照加载到系统中。
通常,可以选择特定的数据快照,并按照时间顺序逐步恢复数据。
2.3 分布式数据恢复在采用分布式数据备份的情况下,数据恢复涉及到从其他节点获取数据并进行同步。
通常,可以从分布式数据备份系统中选择对应的节点并下载数据,最后进行数据合并以实现完整的数据恢复。
数据库备份与恢复方法数据库备份与恢复是数据库管理中非常重要的一部分,它可以确保数据库在发生故障或者数据丢失时能够及时恢复。
本文将介绍常用的数据库备份与恢复方法,以帮助读者有效地保护数据的安全性。
一、全量备份全量备份是数据库备份中最基础和常见的一种方式。
它通过备份整个数据库的所有数据和对象,包括表、索引、存储过程等。
全量备份可以提供最完整的数据库恢复,但其备份和恢复的时间较长,占用的存储空间也较大。
在MySQL数据库中,可以使用mysqldump命令进行全量备份。
例如,执行以下命令可以将整个数据库备份到一个文件中:```mysqldump -u 用户名 -p 密码数据库名 > 备份文件路径.sql```恢复时,可以使用以下命令进行数据库恢复:```mysql -u 用户名 -p 密码数据库名 < 备份文件路径.sql```二、增量备份相对于全量备份,增量备份只备份发生变化的数据部分。
这样可以大大减少备份所需的时间和存储空间。
当需要恢复数据库时,需要先使用全量备份进行基础数据的恢复,再使用增量备份进行增量数据的补充。
在Oracle数据库中,可以使用RMAN(Recovery Manager)进行增量备份。
RMAN提供了一套完整的备份和恢复解决方案,可以管理数据库的全量备份、增量备份和日志备份等。
使用RMAN进行增量备份可以提高备份效率并降低存储成本。
三、冷备份与热备份冷备份是在数据库停止服务的情况下进行的备份操作,这样可以保证备份的数据一致性,但会造成数据库的长时间不可用性。
冷备份适用于一些不需要24小时运行的数据库,备份恢复时间相对较长。
而热备份是在数据库正常运行的情况下进行的备份操作,这样可以保持数据库的可用性,但会影响数据库的性能。
热备份适用于对数据库的高可用性要求较高的场景。
四、远程备份为了防止地域灾难或硬件故障导致数据的永久丢失,远程备份成为一种重要的备份方式。
远程备份就是将数据备份到远程地点的存储设备上,确保即使本地数据中心发生灾难,也能够通过远程备份恢复数据。
Java实现Sqlserver及MySql的备份与还原注:本人是采用Struts1做的一个简单小例子。
实现步骤:1.数据库基类package com.wingo.util;import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;/***@ClassName:DataBaseUtil*@Description:TODO*@author莫希柏*@date Jul4,20122:21:41PM*/public class DataBaseUtil {/***@Description:获取数据库连接*@author莫希柏*@date Jul4,20122:23:11PM*/public static Connection getConnection() {Connection conn = null;try {Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");String url = "jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=datatest";String username = "sa";String password = "sa";conn = DriverManager.getConnection(url, username, password);} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}return conn;}/***@Description:关闭*@author莫希柏*@date Jul4,20122:22:57PM*/public static void closeConn(Connection conn) { if (conn != null) {try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}}2.action类package com.wingo.action;import java.io.BufferedReader;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.OutputStream;import java.io.OutputStreamWriter;import java.sql.CallableStatement;import java.sql.PreparedStatement;import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;import org.apache.struts.action.ActionForm; import org.apache.struts.action.ActionForward; import org.apache.struts.action.ActionMapping; import org.apache.struts.actions.DispatchAction;import com.wingo.util.DataBaseUtil;public class DataAction extends DispatchAction{ /***@Description:SqlServer备份*@author莫希柏*@date Jul4,20122:45:16PM*/public ActionForward doSqlServerBackUp(ActionMapping mapping, ActionForm form,HttpServletRequest request, HttpServletResponse response) throws Exception {String mssqlBackupName=request.getParameter("mssqlBackupName");//自定义备份数据库名String mssqlBackupPath=request.getParameter("mssqlBackupPath");//自定义备份数据库保存路径String dbName="datatest";//被备份的数据库名称boolean flag=false;try {File file = new File(mssqlBackupPath);String path = file.getPath() + "\\"+ mssqlBackupName + ".bak";//备份生成的数据路径及文件名String bakSql = "backup database "+dbName+" to disk=? with init";//备份数据库SQL语句PreparedStatement bak = DataBaseUtil.getConnection().prepareStatement(bakSql);bak.setString(1, path);//path必须是绝对路径bak.execute(); //备份数据库bak.close();flag=true;} catch (Exception e) {flag=false;e.printStackTrace();}response.setCharacterEncoding("utf-8");try {if(flag==true){response.getWriter().print("<script type=\"text/javascript\">alert('SQLSERVER备份成功!');document.location.href='DataAction.do?action=toBackIndex';</script>");}else{response.getWriter().print("<script type=\"text/javascript\">alert('SQLSERVER备份失败!');document.location.href='DataAction.do?action=toBackIndex';</script>");}} catch (IOException e) {e.printStackTrace();}return null;}/***@Description:SqlServer还原*@author莫希柏*@date Jul4,20124:28:05PM*/public ActionForward doSqlServerRecovery(ActionMapping mapping, ActionForm form,HttpServletRequest request, HttpServletResponse response){boolean flag = false;String mssqlRecoveryPath =request.getParameter("mssqlRecoveryPath"); //被还原数据库文件的路径String dbname="datatest";//数据库名称try{File file = new File(mssqlRecoveryPath);String path = file.getPath();//数据库文件名String recoverySql = "ALTER DATABASE "+dbname+" SET ONLINE WITHROLLBACK IMMEDIATE";// 断开所有连接 PreparedStatement ps= DataBaseUtil.getConnection().prepareStatement(recoverySql);CallableStatement cs= DataBaseUtil.getConnection().prepareCall("{call killrestore(?,?)}"); //调用存储过程cs.setString(1, dbname); // 数据库名cs.setString(2, path); // 已备份数据库所在路径cs.execute(); // 还原数据库ps.execute(); // 恢复数据库连接flag=true;} catch (Exception e) {flag=false;e.printStackTrace();}response.setCharacterEncoding("utf-8");try {if(flag==true){response.getWriter().print("<script type=\"text/javascript\">alert('SQLSERVER备份成功!');document.location.href='DataAction.do?action=toBackIndex';</script>");}else{response.getWriter().print("<script type=\"text/javascript\">alert('SQLSERVER备份失败!');document.location.href='DataAction.do?action=toBackIndex';</script>");}} catch (IOException e) {e.printStackTrace();}return null;}/***@Description:MySql备份*@author莫希柏*@date Jul4,20124:39:02PM*/public ActionForward doMySqlBackUp (ActionMapping mapping, ActionForm form, HttpServletRequest request,HttpServletResponse response){boolean flag=false;try {Runtime rt = Runtime.getRuntime();String mySqlBackupName=request.getParameter("mySqlBackupName");//mysql 自定义数据库备份名称String mysqlBackupPath=request.getParameter("mysqlBackupPath");//mysql 自定义数据库备份保存路径String fPath=mysqlBackupPath+mySqlBackupName+".sql";String command="C:/Program Files/MySQL/MySQL Server5.0/bin/mysqldump -uroot -p123456 datatest";//调用 mysql的cmd:Process child = rt.exec(command);// 设置导出编码为utf8。
Java备份oracle数据库/*** 备份oracle数据库** @author 唐俊锋* @param userName* 数据库登录名* @param passWord* 数据库登录密码* @param dataBaseName* 需要备份的数据库名称* @param address* 保存地址;如D:/doc/* @param name* 数据库保存名称* @return 备份的数据库名称*/private void backUpDataBaseOracle(String userName,String passWord,String dataBaseName,String address){// 拼装DOS命令进行数据库备份StringBuffer exp=new StringBuffer("exp ");exp.append(userName);exp.append("/");exp.append(passWord);exp.append("@");exp.append(dataBaseName);exp.append(" file=");/** 得到存储地址的最后一个字符如果有\就直接拼装地址如果没有\就加上/然后拼装数据库名称*/String maxIndex=address.substring(address.length()-1);if("/".equals(maxIndex)||"\\".equals(maxIndex)){exp.append(address);}else{address=address+"\\";exp.append(address);}File file = new File(address);if (!file.exists()) {file.mkdir();}exp.append(dataBaseName);exp.append(".dmp");System.out.println("开始备份........");try {System.out.println(exp.toString());Process p=Runtime.getRuntime().exec(exp.toString());InputStreamReader isr = new InputStreamReader(p.getErrorStream());BufferedReader br = new BufferedReader(isr);String line = null;while ((line = br.readLine()) != null){if(line.indexOf("错误")!=-1){break;}}p.destroy();p.waitFor();System.out.println("备份成功......");} catch (IOException e) {System.out.println(e.getMessage());} catch (InterruptedException e) {System.out.println(e.getMessage());}}Java还原oracle数据库/*** 恢复oracle数据库** @author 唐俊锋* @param userName* 数据库登录名* @param passWord* 数据库登录密码* @param dataBaseName* 需要备份的数据库名称* @param address* 保存地址;如D:/doc/* @param name* 数据库保存名称* @return 备份的数据库名称*/private void resumeDataBaseOracle(String userName, String passWord,String dataBaseName, String address) {// 拼装DOS命令进行数据库备份StringBuffer exp = new StringBuffer("imp ");exp.append(userName);exp.append("/");exp.append(passWord);exp.append("@");exp.append(dataBaseName);exp.append(" file=");/** 得到存储地址的最后一个字符如果有\就直接拼装地址如果没有\就加上/然后拼装数据库名称*/String maxIndex = address.substring(address.length() - 1);if ("/".equals(maxIndex) || "\\".equals(maxIndex)) {exp.append(address);} else {address=address+"\\";exp.append(address);}exp.append(dataBaseName);exp.append(".dmp");File file = new File(address+dataBaseName+".dmp");//判断文件是否存在,存在才进行恢复不存在就不恢复if (file.exists()) {System.out.println("开始恢复........");try {System.out.println(exp.toString());Process p=Runtime.getRuntime().exec(exp.toString());InputStreamReader isr = new InputStreamReader(p.getErrorStream()); BufferedReader br = new BufferedReader(isr);String line = null;while ((line = br.readLine()) != null) {if (line.indexOf("错误") != -1) {break;}}p.destroy();p.waitFor();} catch (IOException e) {System.out.println(e.getMessage());} catch (InterruptedException e) {System.out.println(e.getMessage());}} }。
一、备份数据库1、打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server2、SQL Server组-->双击打开你的服务器-->双击打开数据库目录3、选择你的数据库名称(如论坛数据库Forum)-->然后点上面菜单中的工具-->选择备份数据库4、备份选项选择完全备份,目的中的备份到如果原来有路径和名称则选中名称点删除,然后点添加,如果原来没有路径和名称则直接选择添加,接着指定路径和文件名,指定后点确定返回备份窗口,接着点确定进行备份二、还原数据库1、打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server2、SQL Server组-->双击打开你的服务器-->点图标栏的新建数据库图标,新建数据库的名字自行取3、点击新建好的数据库名称(如论坛数据库Forum)-->然后点上面菜单中的工具-->选择恢复数据库4、在弹出来的窗口中的还原选项中选择从设备-->点选择设备-->点添加-->然后选择你的备份文件名-->添加后点确定返回,这时候设备栏应该出现您刚才选择的数据库备份文件名,备份号默认为1(如果您对同一个文件做过多次备份,可以点击备份号旁边的查看内容,在复选框中选择最新的一次备份后点确定)-->然后点击上方常规旁边的选项按钮5、在出现的窗口中选择在现有数据库上强制还原,以及在恢复完成状态中选择使数据库可以继续运行但无法还原其它事务日志的选项。
在窗口的中间部位的将数据库文件还原为这里要按照你SQL的安装进行设置(也可以指定自己的目录),逻辑文件名不需要改动,移至物理文件名要根据你所恢复的机器情况做改动,如您的SQL 数据库装在D:\Program Files\Microsoft SQL Server\MSSQL\Data,那么就按照您恢复机器的目录进行相关改动改动,并且最后的文件名最好改成您当前的数据库名(如原来是bbs_data.mdf,现在的数据库是forum,就改成forum_data.mdf),日志和数据文件都要按照这样的方式做相关的改动(日志的文件名是*_log.ldf结尾的),这里的恢复目录您可以自由设置,前提是该目录必须存在(如您可以指定d:\sqldata\bbs_data.mdf或者d:\sqldata\bbs_log.ldf),否则恢复将报错6、修改完成后,点击下面的确定进行恢复,这时会出现一个进度条,提示恢复的进度,恢复完成后系统会自动提示成功,如中间提示报错,请记录下相关的错误内容并询问对SQL操作比较熟悉的人员,一般的错误无非是目录错误或者文件名重复或者文件名错误或者空间不够或者数据库正在使用中的错误,数据库正在使用的错误您可以尝试关闭所有关于SQL窗口然后重新打开进行恢复操作,如果还提示正在使用的错误可以将SQL服务停止然后重起看看,至于上述其它的错误一般都能按照错误内容做相应改动后即可恢复三、收缩数据库一般情况下,SQL数据库的收缩并不能很大程度上减小数据库大小,其主要作用是收缩日志大小,应当定期进行此操作以免数据库日志过大1、设置数据库模式为简单模式:打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server-->SQL Server组-->双击打开你的服务器-->双击打开数据库目录-->选择你的数据库名称(如论坛数据库Forum)-->然后点击右键选择属性-->选择选项-->在故障还原的模式中选择“简单”,然后按确定保存2、在当前数据库上点右键,看所有任务中的收缩数据库,一般里面的默认设置不用调整,直接点确定3、收缩数据库完成后,建议将您的数据库属性重新设置为标准模式,操作方法同第一点,因为日志在一些异常情况下往往是恢复数据库的重要依据四、设定每日自动备份数据库强烈建议有条件的用户进行此操作!1、打开企业管理器,在控制台根目录中依次点开Microsoft SQL Server-->SQLServer组-->双击打开你的服务器2、然后点上面菜单中的工具-->选择数据库维护计划器3、下一步选择要进行自动备份的数据-->下一步更新数据优化信息,这里一般不用做选择-->下一步检查数据完整性,也一般不选择4、下一步指定数据库维护计划,默认的是1周备份一次,点击更改选择每天备份后点确定5、下一步指定备份的磁盘目录,选择指定目录,如您可以在D盘新建一个目录如:d:\databak,然后在这里选择使用此目录,如果您的数据库比较多最好选择为每个数据库建立子目录,然后选择删除早于多少天前的备份,一般设定4-7天,这看您的具体备份要求,备份文件扩展名一般都是bak就用默认的6、下一步指定事务日志备份计划,看您的需要做选择-->下一步要生成的报表,一般不做选择-->下一步维护计划历史记录,最好用默认的选项-->下一步完成7、完成后系统很可能会提示Sql Server Agent服务未启动,先点确定完成计划设定,然后找到桌面最右边状态栏中的SQL绿色图标,双击点开,在服务中选择Sql Server Agent,然后点击运行箭头,选上下方的当启动OS时自动启动服务8、这个时候数据库计划已经成功的运行了,他将按照您上面的设置进行自动备份修改计划:1、打开企业管理器,在控制台根目录中依次点开Microsoft SQL Server-->SQL Server组-->双击打开你的服务器-->管理-->数据库维护计划-->打开后可看到你设定的计划,可以进行修改或者删除操作五、数据的转移(新建数据库或转移服务器)一般情况下,最好使用备份和还原操作来进行转移数据,在特殊情况下,可以用导入导出的方式进行转移,这里介绍的就是导入导出方式,导入导出方式转移数据一个作用就是可以在收缩数据库无效的情况下用来减小(收缩)数据库的大小,本操作默认为您对SQL的操作有一定的了解,如果对其中的部分操作不理解,可以咨询动网相关人员或者查询网上资料1、将原数据库的所有表、存储过程导出成一个SQL文件,导出的时候注意在选项中选择编写索引脚本和编写主键、外键、默认值和检查约束脚本选项2、新建数据库,对新建数据库执行第一步中所建立的SQL文件3、用SQL的导入导出方式,对新数据库导入原数据库中的所有表内容。