维护Sql Server中表的索引

  • 发布于:2020-03-12
  • 188 人围观
在使用和创建数据库索引中经常会碰到一些问题,在这里可以采用一些另类的方法解决… 

--第一步:查看是否需要维护,查看扫描密度/Scan Density是否为100% 
declare @table_id int 
set @table_id=object_id( 表名 ) 
dbcc showcontig(@table_id) 

--第二步:重构表索引 
dbcc dbreindex( 表名 ,pk_索引名,100) 

--重做第一步,如发现扫描密度/Scan Density还是小于100%则重构表的所有索引 
--杨铮:并不一定能达100%。 
dbcc dbreindex( 表名 , ,100) 


SQL Server补丁安装常见问题 
谁碰到问题就看看咯:) 

一、补丁安装过程中常见问题 


如果在安装补丁的时候遇到如下类似错误: 

1、安装过程中出现“以前进行的程序创建了挂起的文件操作,运行安装程序前,必须重新启动”,请按照下面步骤解决: 

a、重启机器,再进行安装,如果发现还有该错误,请按下面步骤 
b、在开始->运行中输入regedit 
c、到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager 位置 
d、选择文件->倒出,保存 
e、在右边窗口右击PendingFileRenameOperations,选择删除,然后确认 
f、重启安装,问题解决 

如果还有同样问题,请检查其它注册表中是否有该值存在,如有请删掉。 


2、在安装SQL Server SP3,有时候会出现:无论用windows认证还是混和认证,都出现密码错误的情况,这时查看临时目录下的sqlsp.out,会发现以下描述: 
[TCP/IP Sockets]Specified SQL server not found. 
[TCP/IP Sockets]ConnectionOpen (Connect()). 
其实这是SQL Server SP3的一个小bug,在安装sp3的时候,没有监听tcp/ip端口,可以按照以下步骤进行: 

1、打开SQL server客户器网络实用工具和服务器网络工具,确保启用的协议中包含name pipe,并且位置在第一位. 
2、确保[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Client\ConnectTo] 
"DSQUERY"="DBNETLIB". 
如果没有,请自己建立 
3、停止mssql. 
4、进行安装. 

这样就可以进行正确安装了。 

二、SQL Server补丁版本的检查 

SQL Server的补丁版本检查不如Windows 补丁版本检查直接,一个系统管理员,如果不了解SQL Server版本对应的补丁号,可能也会遇到一点麻烦,因此在这说明一下,通过这样的办法判别机器是安全的办法,不会对系统产生任何影响。 
1、用Isql或者SQL查询分析器登录到SQL Server,如果是用Isql,请在cmd窗口输入isql -U sa,然后输入密码,进入;如果是用SQL查询分析器,请从程序中启动,输入sa和密码(也可以用windows验证)。 
2、在ISQL中输入: 
Select @@Version; 
go 

或者SQL查询分析器中输入(其实如果不想输入,只要打开帮助的关于就可以了:) 
Select @@Version; 
然后按执行; 
这时会返回SQL的版本信息,如下: 
Microsoft SQL Server 2000 - 8.00.760 (Intel X86) Dec 17 2002 14:22:05 Copyright (c) 1988-2003 Microsoft Corporation Enterprise Edition on Windows NT 5.0 (Build 2195: Service Pack 3) 
其中的8.00.760就是SQL Server的版本和补丁号。对应关系如下: 

8.00.194 -——————SQL Server 2000 RTM 
8.00.384 -——————(SP1) 
8.00.534 -——————(SP2) 
8.00.760 -——————(SP3) 

这样我们就能看到SQL Server的正确版本和补丁号了。 

我们也可以用xp_msver看到更详细的信息 

Sql Server数据库的备份和恢复措施 
最常用的操作,新手们看看…… 

一、备份数据库 

1、打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server 
2、SQL Server组-->双击打开你的服务器-->双击打开数据库目录 
3、选择你的数据库名称(如论坛数据库Forum)-->然后点上面菜单中的工具-->选择备份数据库 
4、备份选项选择完全备份,目的中的备份到如果原来有路径和名称则选中名称点删除,然后点添加,如果原来没有路径和名称则直接选择添加,接着指定路径和文件名,指定后点确定返回备份窗口,接着点确定进行备份 
二、还原数据库 

1、打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server 
2、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-->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组-->双击打开你的服务器-->管理-->数据库维护计划-->打开后可看到你设定的计划,可以进行修改或者删除操作 

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

一般情况下,最好使用备份和还原操作来进行转移数据,在特殊情况下,可以用导入导出的方式进行转移,这里介绍的就是导入导出方式,导入导出方式转移数据一个作用就是可以在收缩数据库无效的情况下用来减小(收缩)数据库的大小,本操作默认为您对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/秒)。
万企互联
标签: