科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道SQL Server 数据库操作实用技巧锦集(6)

SQL Server 数据库操作实用技巧锦集(6)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文主要概括安装时提示有挂起的操作、收缩数据库、压缩数据库、转移数据库给新用户以已存在用户权限、检查备份集、修复数据库等操作技巧。

作者:唐云武 来源:赛迪网技术社区 2007年8月31日

关键字: 实用技巧 SQL Server SQL Server 各版本 数据库

  • 评论
  • 分享微博
  • 分享邮件

14.5、设定每日自动备份数据库

1、打开企业管理器,在控制台根目录中依次点开Microsoft SQL Server-->SQL Server组-->双击打开你的服务器。

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组-->双击打开你的服务器-->管理-->数据库维护计划-->打开后可看到你设定的计划,可以进行修改或者删除操作。

14.6、数据的转移(新建数据库或转移服务器)

一般情况下,最好使用备份和还原操作来进行转移数据,在特殊情况下,可以用导入导出的方式进行转移,这里介绍的就是导入导出方式,导入导出方式转移数据一个作用就是可以在收缩数据库无效的情况下用来减小(收缩)数据库的大小,本操作默认为您对SQL的操作有一定的了解,如果对其中的部分操作不理解,可以咨询动网相关人员或者查询网上资料。

1、将原数据库的所有表、存储过程导出成一个SQL文件,导出的时候注意在选项中选择编写索引脚本和编写主键、外键、默认值和检查约束脚本选项。

2、新建数据库,对新建数据库执行第一步中所建立的SQL文件。

3、用SQL的导入导出方式,对新数据库导入原数据库中的所有表内容。

利用数据库日志恢复数据到时间点的操作:

由于不正常的数据丢失,而又不想使用备份数据还原,只要原来有备份且当前日志保存完好,可以采用这个方法。

1、如果误操作之前存在一个全库备份(或已有多个差异备份或增量备份),首先要做的事就是进

进行一次日志备份(如果为了不让日志文件变大而置trunc. log on chkpt.选项且莫为1):

backup log dbName to disk='fileName'

2、恢复一个全库备份,注意需要使用with norecovery,如果还有其他差异或增量备份,则逐个恢复:

restore database dbName from disk='fileName' with norecovery

3、恢复最后一个日志备份即刚做的日志备份,指定恢复时间点到误操作之前的时刻:

restore log dbName from disk='fileName'
with stopat='date_time'

以上这些操作都可以在SQL SERVER企业管理器里完成。

当然,如果误操作是一些不记日志的操作比如truncate table,select into等操作,那么是无法利用上述方法来恢复数据的。

SQL Server2000数据库文件损坏时如何恢复出现这样的问题是比较严重的。SQL Server2000中,如果数据库文件(非系统数据库文件)遇到错误的时候,仅适用于非master,msdb的数据库。

说明如下:

1、 建一个测试数据库test(数据库类型为完全)。

2、 建一个表,插入点记录:

create table a(c1 varchar(2))
go
insert into a values('aa')
go
insert into a values('bb')
go

3、 作完全备份,到文件test_1.bak。

4、 在作一点修改:

insert into a values('cc')
go
create table b(c1 int)
go
insert into b values(1)
go
insert into b values(2)
go

5、 shutdown 数据库服务器。

6、 用ultraedit编辑数据库文件test_data.mdf,随便修改点字节内容,相当于数据库遭到致命的损坏。

7、 启动数据库,并且运行企业管理器,点开数据库,看到test变成灰色,而且显示置疑。

8、 运行:

isql -SLocalhost -Usa -P  
1> backup log test TO DISK=
'D:Program FilesMicrosoft SQL ServerMSSQLBACKUP 
est_2.bak' WITH NO_TRUNCATE
2>go

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

BACKUP LOG 操作成功地处理了 2 页,花费了 0.111 秒(0.087 MB/秒)。

9、 进行恢复最老的完全备份:

1> RESTORE DATABASE test FROM DISK='D:Program FilesMicrosoft SQL ServerMSSQL
BACKUP est_1.bak' WITH NORECOVERY
2> go

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

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

RESTORE DATABASE 操作成功地处理了 97 页,花费了 0.107 秒(7.368 MB/秒)。

10、 恢复最近的日志:

1> RESTORE LOG test FROM DISK='D:Program FilesMicrosoft SQL ServerMSSQLBACKU
P est_2.bak' WITH RECOVERY
2> go

已处理 2 页,这些页属于数据库 'test' 的文件 'TEST_Log'(位于文件 1 上),RESTORE LOG 操作成功地处理了 2 页,花费了 0.056 秒(0.173 MB/秒)。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章