`
阅读更多
原帖地址:http://www.cnblogs.com/kerrycode/archive/2013/05/28/3104214.html

    MS SQL的日志信息/日志记录,可能对你来说,既熟悉又陌生,熟悉是因为你可能一直都在使用,查看、关注一些日志信息/记录,例如,作业历史记录;陌生是因为你可能从不关注日志信息/记录的管理,这里我一直用日志信息/记录这个词,而没有用日志文件这个词来阐述,是想让大家把它和事务日志文件(ldf)区分开来,网上你用日志文件做搜索关键词,可能搜出来的都是事务日志相关的信息。其实它真的也叫日志文件,这篇文章我大概从日志记录分类、如何查看日志记录、日志记录的位置、日志记录的设置、为什么错误日志会暴增、如何清除日志记录等方面来讲述。



日志记录分类


按日志文件查看器,习惯将错误日志归为SQL SERVER、 SQL SERVER 代理, Windows应用程序日志,数据库邮件等四类错误日志记录。如果还考虑维护计划、远程维护计划、作业历史记录日志信息,总共是7类日志信息文件。


clip_image002


其中Windows应用程序日志类型又分为系统日志(System)、安全日志(Security)、应用程序日志(Application), PatchLink日志等几种,我在服务器(Windows Server  2008 R2 Standard)上打开SSMS,居然发现又多了HardwareEvents, Internet Explorer、Windows PowerShell等日志文件。这些都是系统的日志文件。你不必太纠结有多少种。


clip_image004


日志记录位置


 


SQL SERVER日志记录、 SQL SERVER代理记录的位置如下所示, SQL SERVER日志记录一般存储在ERRORLOG.n(n为数字)文件里, SQL SERVER代理日志记录位于SQLAGENT.n这类的文件里。当然这跟数据库的版本也有关系:






















版本



路径



SQL SERVER 2005



Program Files\Microsoft SQL Server\MSSQL.n\MSSQL\LOG



SQL SERVER 2008



Program Files\Microsoft SQL Server\MSSQL10.实例名\MSSQL\LOG



SQL SERVER 2008 R2



Program Files\Microsoft SQL Server\MSSQL10_50.实例名\MSSQL\LOG



    SQL SERVER 2005,默认情况下,错误日志位于 Program Files\Microsoft SQL Server\MSSQL.n\MSSQL\LOG\ERRORLOG 和 ERRORLOG.n 文件中。其中MSSQL.n的区分为:


        MSSQL.1:SQLSERVER


        MSSQL.2:SSAS


        MSSQL.3:SQLExpress


        MSSQL.4:SSRS


所以,一般情况下,你只需要关注MSSSQL.1目录下的日志文件


clip_image006


那么,数据库邮件日志记录位于哪里呢?作业历史记录日志信息、Windows应用程序日志又位于哪里呢?是不是从没考虑过这些?


数据库邮件日志记录信息可以从视图msdb.dbo.sysmail_event_log查询得到,实质保存在[dbo].[sysmail_log]表里面。




sysmail_event_log


  1.   SELECTlog_id ,

  2.         CASE event_type

  3.           WHEN 0 THEN 'success'

  4.           WHEN 1 THEN 'information'

  5.           WHEN 2 THEN 'warning'

  6.           ELSE 'error'

  7.         END AS event_type ,

  8.         log_date ,

  9.         description ,

  10.         process_id ,

  11.         sl.mailitem_id ,

  12.         account_id ,

  13.         sl.last_mod_date ,

  14.         sl.last_mod_user

  15.     FROM[dbo].[sysmail_log] sl

  16. WHERE   ( ISNULL(IS_SRVROLEMEMBER(N'sysadmin'), 0) = 1 )

  17.         OR( EXISTS( SELECT    mailitem_id

  18.                       FROM      [dbo].[sysmail_allitems] ai

  19.                       WHERE     sl.mailitem_id = ai.mailitem_id ) )




作业历史记录日志信息都保存在msdb.dbo.sysjobhistory的表里面,其中run_status字段代表作业执行状态


0 = 失败


1 = 成功


2 = 重试


3 = 已取消


4= 正在进行


所有Windows应用程序日志其实都位于同一位置%SystemRoot%\System32\Winevt\Log。像Application日志文件位于%SystemRoot%\System32\Winevt\Logs\Application.evtx,如下所示,


clip_image008


查看日志记录



查看日志记录可以确保进程(例如,备份和还原操作、批处理命令或其他脚本和进程)成功完成。此功能可用于帮助检测任何当前或潜在的问题领域,包括自动恢复消息(尤其是在 SQL Server 实例已停止并重新启动时)、内核消息或其他服务器级错误消息。



方式1: 查看错误日志文件


对SQL SERVER、SQL SERVER AGENT日志记录信息,你可以直接去log目录下找到ERRORLOG、SQLAGENT日志文件,直接打开查看;而像Windows应用程序日志记录,去到%SystemRoot%\System32\Winevt\Log目录,找到对应的日志文件,直接打开查看。


 


方式2:通过SSMS来查看日志记录


查看与常规 SQL Server 活动相关的日志



  1. 在对象资源管理器中,依次展开“管理”“SQL Server 日志”,再双击“当前<日期/时间>,将显示 SQL Server“SQL 代理”“Windows 事件”日志。


查看与作业相关的日志



  1. 在对象资源管理器中,展开“SQL Server 代理”,右键单击“作业”,再单击“查看历史记录”,此时将显示“作业历史记录”“SQL 代理”日志。


查看与维护计划相关的日志



  1. 在对象资源管理器中,展开“管理”,右键单击“维护计划”,再单击“查看历史记录”,此时将显示“维护计划”“作业历史记录”“SQL 代理”日志。


 


方式3:用脚本查看


3.1 对于SQL SERVER日志文件,可以通过下面脚本查看:


   --查看日志文件的存档号


    EXEC master.dbo.sp_enumerrorlogs


   用这个命令可以查看日志文件的大小,这个非常有用,你可以把大小异常的文件给排查出来。


 


   --根据存档号查看该档日志内容


   EXEC master.dbo.xp_readerrorlog 1


   --根据job_id查看SQL SERVER日志记录


  SELECT * FROM  msdb.dbo.sysjobhistory WHERE job_id='36E9232B-CD5B-4646-9BED-B8242090FFF9'


 


3.2 对于作业历史记录日志信息,你既可以通过下面存储过程查看,也可以直接查询对应的表。


例如,我要查看作业“ServerDiskCapacityCheck”的历史记录




Code Snippet


  1.  

  2.  

  3. USE msdb ;

  4.  

  5. GO

  6.  

  7. EXEC dbo.sp_help_jobhistory

  8.  

  9. @job_name = N'ServerDiskCapacityCheck' ;

  10.  

  11. GO

  12.  

  13. »ò

  14.  

  15.   SELECT      j.name AS  [JOB_NAME] ,

  16.  

  17.             h.step_id AS  [Step] ,  

  18.  

  19.             h.step_name AS  [STEP_NAM] ,  

  20.  

  21.             h.MESSAGE AS  [Message] ,  

  22.  

  23.             [Status]    = CASE WHEN h.run_status = 0 THEN 'Failed'  

  24.  

  25.             WHEN h.run_status = 1 THEN 'Succeeded'  

  26.  

  27.             WHEN h.run_status = 2 THEN 'Retry'  

  28.  

  29.             WHEN h.run_status = 3 THEN 'Canceled'  

  30.  

  31.             END,  

  32.  

  33.             h.run_date AS  [RunDate] ,  

  34.  

  35.             h.run_time AS  [RunTime] ,  

  36.  

  37.             h.run_duration  AS  [RunDuration]

  38.  

  39.   FROM        sysjobs j

  40.  

  41.     INNER JOIN  sysjobhistory h ON h.job_id = j.job_id

  42.  

  43. WHERE h.run_date>=CONVERT(CHAR(8),GETDATE()-1,112) AND h.run_status<>1   

  44.  

  45.   /* WHERE    j.name = 'Job_Name' */

  46.  

  47.     ORDER BYh.run_date, h.run_time




 


3.3数据库邮件记录查看


SELECT * FROM  msdb.dbo.sysmail_event_log;


 


日志记录管理


 


设置最大错误日志文件数


    1:在对象资源管理器中,连接到 SQL Server 数据库引擎实例,再展开该实例。


    2:在”管理“选项,选择”SQL SERVER日志”,单击右键选择配置。 顺便说一下,很多网上资料说,SQL SERVER默认保留前6个日志文件,但是我查看了SQL SERVER 2005和SQL SERVER 2008,都是默认保留30个,有时候需要自己去验证、实验,不要人人亦云。估计这个说法是SQL SERVER 2000时的配置了。


clip_image010


当然,你也可以用命令设置:




USE [master]

<!--CRLF-->
 

<!--CRLF-->
GO

<!--CRLF-->
 

<!--CRLF-->
EXEC xp_instance_regwrite N'HKEY_LOCAL_MACHINE', N'Software\Microsoft\MSSQLServer\MSSQLServer', N'NumErrorLogs', REG_DWORD, 10

<!--CRLF-->
 

<!--CRLF-->
GO

<!--CRLF-->
 

<!--CRLF-->


设置错误日志文件存放目录


1:在对象资源管理器中,连接到 SQL Server 数据库引擎实例,再展开该实例。


2:展开“SQL SERVER”代理。


3:右键单击”错误日志“,然后选择配置选项,如下所示:


clip_image012


4:在”错误日志文件“选项中,输入新的路径和文件名,或使用浏览(...)按钮进行查找。重新启动SQL SERVER代理服务后,SQL SERVER代理才写入到新的日志文件。


clip_image014


 


 


设置作业历史记录日志



  1. 对象资源管理器中,连接到 SQL Server 数据库引擎 实例,再展开该实例。

  2. 右键单击“SQL Server 代理”,再单击“属性”

  3. “SQL Server 代理属性”对话框中,选择“历史记录”页。

  4. 从下列选项中选择:


  • 选中“限制作业历史记录日志的大小”,然后键入作业历史记录日志的最大行数和每个作业的最大行数。

  • 选中“自动删除代理历史记录”,然后指定时间段。这样,早于此时间段的历史记录将从日志中清除。


  • clip_image016



为什么错误日志文件暴增?



这里我说的不仅仅指某个错误日志记录文件暴增,也指目录Program Files\Microsoft SQL Server\MSSQL.n\MSSQL\LOG所占空间暴增,如果你平时都不关注这些错误日志,也从不维护错误日志记录文件,那么很有可能它所占的空间非常大,大到让你吃惊的地步。几十G的我也见过,那么具体原因可能有以下种(如果大家还碰到过其它情况,欢迎补充):



 


1:SQL 内部错误的时候会产生非常多的DUMP文件,如下所示


clip_image018


2:高可用的数据库服务器可能很少停机,而你又没有定期清理、清空这些错误日志信息,那么ERRORLOG.n/SQLAGENT.n文件增长会非常大。这样对于DBA使用错误日志查找信息就会比较困难,而且日志大了加载、写入以后性能也会受到影响。


3:其实还有一个情况,如果你数据库IP地址曝露在外网时,会遭到大量尝试登录sa的攻击,也会产生大量的审核失败日志信息。


4:就是一些SQL SERVER PROFILE文件没有删除,当然,这个本质跟日志文件暴增没啥关系,但是跟LOG文件夹的大小有些关系。


如何清理错误日志:



对于SQL SERVER日志、SQL SERVER AGENT日志记录,微软提供了一个存储过程sp_cycle_errorlog可以实现日志的循环。 这个存储过程的作用是关闭当前的错误日志文件,并循环错误日志扩展编号(就像重新启动服务器)。每次启动SQL Server 时,都会将当前错误日志重命名为errorlog.1errorlog.1 变为errorlog.2errorlog.2 变为errorlog.3,依次类推。最后一个errorlog.n将会被删除。sp_cycle_errorlog 可使您循环访问错误日志文件,而不必停止和启动服务器。



另外:日志过大说明你没有截断错误日志,错误日志是可以截断的,进入你的数据库输入DBCC ERRORLOG


每执行一次,当前的错误日志退出,让后建立新的错误日志,你只能删除 ERRORLOGn的错误日志没有号码的是正在使用的日志,删除会报错,如果它比较大,就DBCC ERRORLOG,而后他会变成ERRORLOG+编号,你就可以删除了,另外建议你把这些ERRORLOG 放到其他盘符,比较好管理。


对于 Windows应用程序日志,一般都有默认的大小设置,以及按需要覆盖。这些配置一般也是最优的配置。所以这块除非你有特殊需求,否则不用你操心。


 


 


clip_image020









对于邮件日志记录,存储过程sysmail_delete_log_sp提供从数据库邮件日志中删除事件。删除日志中的所有事件或删除符合某一日期或类型条件的那些事件


sysmail_delete_log_sp [ [ @logged_before = ] 'logged_before' ]


[, [ @event_type = ] 'event_type' ]



 


 删除参数指定的所有 SQL Server 代理作业步骤日志。使用此存储过程可维护 msdb 数据库中的 sysjobstepslogs 表。


sp_delete_jobsteplog { [ @job_id = ] 'job_id' | [ @job_name = ] 'job_name' }


[ , [ @step_id = ] step_id | [ @step_name = ] 'step_name' ]


[ , [ @older_than = ] 'date' ]


[ , [ @larger_than = ] 'size_in_bytes' ]


 


删除作业的历史记录


删除特定作业YourSQLDba_LogBackups的历史记录。


USE msdb ;


GO


EXEC dbo.sp_purge_jobhistory


@job_name = N'YourSQLDba_LogBackups' ;


GO


以下示例将不带参数执行此过程以删除所有的历史记录。




USE msdb ;


GO


EXEC dbo.sp_purge_jobhistory ;


GO


 


删除参数指定的所有 SQL Server 代理作业步骤日志。使用此存储过程可维护 msdb 数据库中的 sysjobstepslogs 表。如果你想好好维护日志记录,那么你可以整合上面的思想方法到一个存储过程,然后配置一个作业来定期清理日志记录,接下来我们看看YourSQLDba的方法吧




Code Snippet


  1. USE [YourSQLDba]

  2. GO

  3.  

  4. /****** Object:  StoredProcedure [yMaint].[LogCleanup]    Script Date: 05/28/2013 18:36:21 ******/

  5. SET ANSI_NULLS ON

  6. GO

  7.  

  8. SET QUOTED_IDENTIFIER ON

  9. GO

  10.  

  11. -----------------------------------------------------------------------------

  12. -- yMaint.LogCleanup (for entries older than 30 days)

  13. -- Mail logs

  14. -- Backup history logs

  15. -- Job history

  16. -- Cycle SQL Server error log

  17. -----------------------------------------------------------------------------

  18. create proc [yMaint].[LogCleanup]

  19.   @jobNo Int

  20. as

  21. Begin

  22.   declare @d nvarchar(8)

  23.   declare @lockResult int

  24.   declare @sql nvarchar(max)

  25.  

  26.   Begin try

  27.  

  28.   exec yMaint.LockMaintDb@jobNo=@jobNo, @lockType='C', @DbName = 'LogCleanUpStep', @Result = @lockResult output

  29.   If @lockResult > 0

  30.     Return;

  31.  

  32.   Set @sql = 'Exec msdb.dbo.sysmail_delete_log_sp @logged_before = "<d>";'

  33.   Set @sql = replace(@sql, '<d>', convert(nvarchar(8), dateadd(dd, -30, getdate()), 112))

  34.   Set @sql = replace(@sql, '"', '''')

  35.   Exec yExecNLog.LogAndOrExec

  36.     @context = 'yMaint.LogCleanup'

  37.   , @info = 'Cleanup log entries older than 30 days, begins with mail'

  38.   , @sql = @sql

  39.   , @JobNo = @JobNo

  40.   

  41.   Set @sql = 'EXECUTE msdb.dbo.sysmail_delete_mailitems_sp  @sent_before = "<d>";'

  42.   Set @sql = replace(@sql, '<d>', convert(nvarchar(8), dateadd(dd, -30, getdate()), 112))

  43.   Set @sql = replace(@sql, '"', '''')

  44.   Exec yExecNLog.LogAndOrExec

  45.     @context = 'yMaint.LogCleanup'

  46.   , @info = 'Cleanup log entries older than 30 days, for mailitems'

  47.   , @sql = @sql

  48.   , @JobNo = @JobNo

  49.  

  50.   -- clean backup history

  51.   Set @sql = 'exec  Msdb.dbo.sp_delete_backuphistory   @oldest_date = "<d>" '

  52.   Set @sql = replace(@sql, '<d>', convert(nvarchar(8), dateadd(dd, -30, getdate()), 112))

  53.   Set @sql = replace(@sql, '"', '''')

  54.   Exec yExecNLog.LogAndOrExec

  55.     @context = 'yMaint.LogCleanup'

  56.   , @info = 'Cleanup log entries older than 30 days, for backup history'

  57.   , @sql = @sql

  58.   , @JobNo = @JobNo

  59.   

  60.   -- clean sql agent job history

  61.   Set @sql = 'EXECUTE  Msdb.dbo.sp_purge_jobhistory  @oldest_date = "<d>"'

  62.   Set @sql = replace(@sql, '<d>', convert(nvarchar(8), dateadd(dd, -30, getdate()), 112))

  63.   Set @sql = replace(@sql, '"', '''')

  64.   Exec yExecNLog.LogAndOrExec

  65.     @context = 'yMaint.LogCleanup'

  66.   , @info = 'Cleanup log entries older than 30 days, for job history'

  67.   , @sql = @sql

  68.   , @JobNo = @JobNo

  69.   

  70.   -- clean job maintenance job history (SQL Server own maintenance)

  71.   Set @sql = 'EXECUTE  Msdb.dbo.sp_maintplan_delete_log null,null,"<d>"'

  72.   Set @sql = replace(@sql, '<d>', convert(nvarchar(8), dateadd(dd, -30, getdate()), 112))

  73.   Set @sql = replace(@sql, '"', '''')

  74.   Exec yExecNLog.LogAndOrExec

  75.     @context = 'yMaint.LogCleanup'

  76.   , @info = 'Cleanup log entries older than 30 days, for SQL Server job maintenace plans'

  77.   , @sql = @sql

  78.   , @JobNo = @JobNo

  79.   

  80.   -- archive current log, and start a new one

  81.   Set @sql = 'Execute sp_cycle_errorlog'

  82.   Set @sql = replace(@sql, '<d>', convert(nvarchar(8), dateadd(dd, -30, getdate()), 112))

  83.   Set @sql = replace(@sql, '"', '''')

  84.   Exec yExecNLog.LogAndOrExec

  85.     @context = 'yMaint.LogCleanup'

  86.   , @info = 'Recycle Sql Server error log, start a new one'

  87.   , @sql = @sql

  88.   , @JobNo = @JobNo

  89.  

  90.   Delete H

  91.   From

  92.     (

  93.     Select distinct JobNo --

  94.     From  Maint.JobHistory

  95.     Where JobStart < dateadd(dd, -30, getdate())

  96.     ) as T

  97.     join

  98.     Maint.JobHistory H  

  99.     On H.JobNo = T.JobNo

  100.  

  101.   End try

  102.   Begin catch

  103.     exec yMaint.UnLockMaintDb@jobNo=@jobNo, @DbName = 'LogCleanUpStep'

  104.     Exec yExecNLog.LogAndOrExec

  105.         @context = 'yMaint.LogCleanup'

  106.       , @Info = 'Error caught in proc'  

  107.       , @err = '?'

  108.       , @JobNo = @JobNo

  109.   End Catch

  110.  

  111.   exec yMaint.UnLockMaintDb@jobNo=@jobNo, @DbName = 'LogCleanUpStep'

  112.  

  113. End -- yMaint.LogCleanup

  114.  

  115. GO




参考资料:


http://msdn.microsoft.com/zh-cn/library/ms187885(v=sql.105).aspx


http://www.jb51.net/article/26988.htm


http://groundsel.itpub.net/post/1284/494264


http://www.canway.net/Lists/CanwayOriginalArticels/DispForm.aspx?ID=291


http://technet.microsoft.com/zh-cn/library/ms191202(v=SQL.105).aspx


http://support.microsoft.com/kb/157804/zh-cn


http://support.microsoft.com/kb/115519/zh-cn


http://blog.csdn.net/smithliu328/article/details/7843724


http://blog.csdn.net/claro/article/details/5660524


http://www.cnblogs.com/lyhabc/archive/2013/02/12/2910623.html


 

本文链接

分享到:
评论

相关推荐

    ms sql 日志文件压缩

    在Microsoft SQL Server数据库管理系统中,日志文件(.ldf文件)存储了所有数据库的事务日志信息,包括数据修改、备份和恢复等操作。这些日志对于数据库的正常运行和故障恢复至关重要。然而,随着时间的推移,日志...

    SQL语句帮助文档 - MS SQL

    8. **备份与恢复**:MS SQL Server提供了多种备份类型(完整、差异、日志),以及对应的恢复模式,确保数据安全和业务连续性。 通过上述的`Transact-SQL CHN.chi`和`Transact-SQL CHN.chm`文档,用户可以详细学习到...

    ms SQL 和 sql anywhere 数据库管理实用工具源码

    4. 异常处理与日志记录:为了保证系统的稳定性和可维护性,源码中可能会有错误捕获和日志记录的代码,以追踪和分析程序运行中的问题。 5. 并发与事务处理:对于多用户环境,源码可能涉及到并发控制和事务处理,确保...

    SQL Server数据库状态监控 – 错误日志

    错误日志记录了数据库服务器在运行过程中遇到的问题、警告以及重要事件,帮助管理员了解系统的健康状况,并在出现问题时定位和解决问题。 1. **错误日志的分类** - **Windows事件日志**:Windows操作系统提供了...

    一个短小精悍的MS SQL Server数据库日志清除工具程序。.rar

    3. **日志截断**:通过T-SQL命令(如`DBCC SHRINKFILE`),工具会截断日志文件,删除不再需要的旧日志记录。 4. **日志收缩**:截断后,工具可能会进一步收缩日志文件,将其大小调整到更合理的水平,以优化磁盘空间...

    MSSQL日志解析和浏览工具

    一款真正意义上的MSSQL日志分析和浏览工具,直接解析LDF文件,支持SQL2008,SQL2005,SQL2000. 程序主要功能: 1:\l日志浏览....在对应的日志记录上右键,弹出菜单,点 &lt;浏览数据&gt; .可以查看事务删除的数据.

    MS SQL SERVER日志收缩工具,效率非常高

    在SQL Server数据库管理中,日志文件(Log File)是用于记录所有事务处理的重要部分,它维护了数据库的完整性和一致性。然而,随着时间的推移,日志文件可能会变得非常大,占用大量的磁盘空间,这可能会影响系统性能...

    MS SQL误操作恢复/日志记录查看 汉化破解版

    MS SQL误操作恢复/日志记录查看 汉化破解版,实时查看谁动了你的数据库,一目了然。当你自己执行语句出现失误,可以进行撤销操作,避免数据的不准确,是很好的工具!操作简单,一用就会!

    MS SQL Client

    8. **日志记录与错误处理**:良好的日志记录功能可以追踪和诊断问题,而错误处理机制则能帮助用户理解并解决问题,提高工作效率。 9. **用户界面**:用户友好的界面设计是必不可少的,包括清晰的操作指引、快捷键...

    SQL Server 2000 日志浏览器

    在数据库管理中,事务日志至关重要,因为它记录了所有数据库更改操作,对于数据恢复、故障排查和性能优化具有关键作用。以下是对SQL Server 2000日志浏览器及其相关知识点的详细解释: 1. **事务日志**:在SQL ...

    ms-sql数据库日志清理

    在简单恢复模式下,日志截断更为频繁,而完整恢复模式则保留所有日志记录以支持完全恢复。 5. **定期维护计划**:设置定期的日志清理任务是保持数据库健康运行的关键。这可以通过SQL Server代理或第三方工具实现,...

    10分钟学会MS SQL (2005)

    在十分钟内掌握MS SQL Server 2005可能听起来有些挑战,但别担心,我们会逐步讲解这个强大的数据库管理系统的关键概念和操作。SQL Server 2005是Microsoft公司推出的一款企业级数据库解决方案,广泛应用于数据存储、...

    MS_Sql_Server_log_clear.rar_MS SQL Server_delphi sql

    1. MS SQL Server日志:SQL Server数据库的日志,也称为交易日志(Transaction Log),用于记录所有事务操作,确保数据的一致性和可恢复性。日志文件会随着时间的推移而增长,如果不定期清理,可能会影响数据库性能...

    mssql日志清理工具

    【MSSQL日志清理工具】是一款专门针对Microsoft SQL Server数据库的日志管理工具,它能够有效地帮助管理员清理和管理数据库的日志文件,适用于SQL Server 2000、2005以及2008这三个版本。日志文件在数据库系统中起着...

    sql 2012收缩日志.pdf

    SQL Server的日志文件存储了数据库事务的所有日志记录,包括提交或回滚事务所需的所有信息。日志文件的存在是为了保证数据的完整性和一致性,以防系统故障时能够恢复数据到最近的一致状态。 在SQL Server 2012中,...

    MS SQL数据库备份和恢复存储过程

    在MS SQL Server中,数据库备份和恢复是维护数据安全与完整性的关键操作。本文将详细介绍如何使用存储过程来实现这两个功能。 首先,我们来看备份数据库的存储过程`pr_backup_db`。这个存储过程用于创建一个数据库...

    PostgreSQL_与_MS_SQLServer比较

    在数据库领域,PostgreSQL 和 MS SQL Server 都是非常受欢迎的关系型数据库管理系统。两者在很多方面都提供了强大的功能支持,但在具体实现细节上存在不少差异。本文将从以下几个方面进行详细的比较: #### 数据...

    Acronis Recovery for MS SQL Server

    根据提供的文件信息,我们可以深入探讨有关“Acronis Recovery for MS SQL Server”的知识点。这里将主要围绕该软件的功能、用途以及版本相关信息展开讨论。 ### Acronis Recovery for MS SQL Server #### 软件...

    MS Sql Server 2000定期备份数据

    MS Sql Server 2000是微软推出的一款关系型数据库管理系统,广泛应用于企业级应用中。它提供了强大的数据存储、处理和管理功能,并支持多种高级特性,比如存储过程、触发器等,能够满足复杂的应用需求。 #### 知识...

    【MS SQL Server】安全基线及安全加固指南v1.0.pdf

    在安全审计方面,需要启用日志记录功能,并设置日志目录权限,以保证日志的可追溯性与安全性。 资源控制方面,涉及了设置连接协议和监听的IP范围、连接超时、限制远程用户连接数量以及内存限制等,以防止资源滥用。...

Global site tag (gtag.js) - Google Analytics