当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-05-02 15:21:00  来源:本站整理

<b>SQL SERVER实用经验本领集 [一]</b>[MSSQL防范]

赞助商链接



  本文“<b>SQL SERVER实用经验本领集 [一]</b>[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

  此文是sql server实用操作小本领调集,包含安装时提醒有挂起的操作、收缩数据库、紧缩数据库、转移数据库给新用户以已存在用户权限、查抄备份集、修复数据库等.草地chin ai tp owerftGjY

  (一)挂起操作草地chin ai tp owerftGjY

  在安装Sql或sp补钉的时刻系统提醒之前有挂起的安装操作,要求重启,这里常常重启无用,办理办法:

  到HKEY_LOCAL_MacHINE\SYSTEM\CurrentControlSet\Control\Session Manager
  删除PendingFileRenameOperations草地chin ai tp owerftGjY




  (二)收缩数据库草地chin ai tp owerftGjY


  --重建索引
  DBCC REINDEX
  DBCC INDEXDEFRAG
  --收缩数据和日记
  DBCC SHRINKDB
  DBCC SHRINKFILE草地chin ai tp owerftGjY

草地chin ai tp owerftGjY

 草地chin ai tp owerftGjY

  (三)紧缩数据库草地chin ai tp owerftGjY


  dbcc shrinkdatabase(dbname)草地chin ai tp owerftGjY

草地chin ai tp owerftGjY

 草地chin ai tp owerftGjY

  (四)转移数据库给新用户以已存在用户权限草地chin ai tp owerftGjY


  exec sp_change_users_login 'update_one','newname','oldname'
  go草地chin ai tp owerftGjY

草地chin ai tp owerftGjY

  (五)查抄备份集草地chin ai tp owerftGjY


  RESTORE VERIFYONLY from disk='E:\dVBbs.bak'草地chin ai tp owerftGjY

草地chin ai tp owerftGjY

  (六)修复数据库草地chin ai tp owerftGjY


  ALTER DATABASE [dvbbs] SET SINGLE_USER
  GO
  DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK
  GO
  ALTER DATABASE [dvbbs] SET MULTI_USER
  GO草地chin ai tp owerftGjY

  --CHECKDB 有3个参数:草地chin ai tp owerftGjY

  --REPAIR_ALLOW_DATA_LOSS 草地chin ai tp owerftGjY

草地chin ai tp owerftGjY








  --  履行由 REPAIR_REBUILD 完成的全部修复,包含对行和页举行分配和撤消分配以改正分配错误、构造行或页的错误,以及删除已破坏的文本对象.这些修复大概会招致一些数据丧失.修复操作可以在用户事件下完成以答应用户回滚所做的更改.假如回滚修复,则数据库仍会含有错误,应当从备份举行恢复.假如由于所供应修复等级的来由遗漏某个错误的修复,则将遗漏任何取决于该修复的修复.修复完成后,备份数据库.

  --REPAIR_FAST 举行小的、不耗时的修复操作,如修复非堆积索引中的附加键.这些修复可以很快完成,并且不会有丧失数据的危险. 草地chin ai tp owerftGjY

  --REPAIR_REBUILD 履行由 REPAIR_FAST 完成的全部修复,包含需求较长时间的修复(如重建索引).履行这些修复时不会有丧失数据的危险. 草地chin ai tp owerftGjY


  --DBCC CHECKDB('dvbbs') with NO_INFOMSGS,PHYSICAL_ONLY草地chin ai tp owerftGjY

草地chin ai tp owerftGjY

  SQL SERVER日记排除的两种办法
  在利用历程中大家常常碰到数据库日记非常大的情形,在这里介绍了两种处理办法…… 草地chin ai tp owerftGjY

  办法一草地chin ai tp owerftGjY

  普通情形下,SQL数据库的收缩并不能很大程度上减小数据库大小,其主要作用是收缩日记大小,该当按期举行此操作免得数据库日记过大草地chin ai tp owerftGjY

  1、设置数据库情势为简单情势:翻开SQL企业管理器,在掌握台根目录中顺次点开Microsoft SQL Server-->SQL Server组-->双击翻开你的服务器-->双击翻开数据库目录-->挑选你的数据库名称(如论坛数据库Forum)-->然后点击右键挑选属性-->挑选选项-->在弊端复原的情势中挑选"简单",然后按肯定保存.草地chin ai tp owerftGjY

  2、在当前数据库上点右键,看全部任务中的收缩数据库,普通里面的默许设置不用调整,直接点肯定.草地chin ai tp owerftGjY

  3、收缩数据库完成后,倡议将您的数据库属性重新设置为尺度情势,操作办法同第一点,因为日记在一些非常情形下常常是恢复数据库的重要根据草地chin ai tp owerftGjY

  办法二草地chin ai tp owerftGjY


  SET NOCOUNT ON
  DECLARE @LogicalFileName sysname,
  @MaxMinutes INT,
  @NewSize INT草地chin ai tp owerftGjY

  USE     tablename             -- 要操作的数据库名
  SELECT  @LogicalFileName = 'tablename_log',  -- 日记文件名
  @MaxMinutes = 10,               -- Limit on time allowed to wrap log.
  @NewSize = 1                  -- 你想设定的日记文件的大小(M)草地chin ai tp owerftGjY

草地chin ai tp owerftGjY







草地chin ai tp owerftGjY


  -- Setup / initialize
  DECLARE @OriginalSize int
  SELECT @OriginalSize = size
  FROM sysfiles
  WHERE name = @LogicalFileName
  SELECT 'Original Size of ' + db_name() + ' LOG is ' +
  CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' +
  CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB'
  FROM sysfiles
  WHERE name = @LogicalFileName
  CREATE TABLE DummyTrans
  (DummyColumn char (8000) not null)草地chin ai tp owerftGjY

草地chin ai tp owerftGjY


  DECLARE @Counter   INT,
  @StartTime DATETIME,
  @TruncLog  VARCHAR(255)
  SELECT  @StartTime = GETDATE(),
  @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY'草地chin ai tp owerftGjY

  DBCC SHRINKFILE (@LogicalFileName, @NewSize)
  EXEC (@TruncLog)
  -- Wrap the log if necessary.
  WHILE     @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired
  AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName) 
  AND (@OriginalSize * 8 /1024) > @NewSize 
  BEGIN -- Outer loop.
  SELECT @Counter = 0
  WHILE  ((@Counter < @OriginalSize / 16) AND (@Counter < 50000))
  BEGIN -- update
  INSERT DummyTrans VALUES ('Fill Log') 
  DELETE DummyTrans
  SELECT @Counter = @Counter + 1
  END  
  EXEC (@TruncLog) 
  END  
  SELECT 'Final Size of ' + db_name() + ' LOG is ' +
  CONVERT(VARCHAR(30),size) + ' 8K pages or ' +
  CONVERT(VARCHAR(30),(size*8/1024)) + 'MB'
  FROM sysfiles
  WHERE name = @LogicalFileName
  DROP TABLE DummyTrans
  SET NOCOUNT OFF 草地chin ai tp owerftGjY


草地chin ai tp owerftGjY

  [未完待续]
草地chin ai tp owerftGjY





  以上是“<b>SQL SERVER实用经验本领集 [一]</b>[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .