sql-server-2005 – 缩小镜像生产数据库上的事务日志文件的最简单方法

在镜像生产数据库上收缩事务日志文件的最简单方法是什么?

我必须,因为我的磁盘空间不多了.

我会在执行此操作之前进行完整的数据库备份,因此我不需要保留事务日志中的任何内容(对吧?我每天都有完整的数据库备份,可能永远不需要时间点恢复,但我会保留如果我可以打开选项 – 这就是所有的.ldf都是真的,对吗?).

解决了:
好的,在通过SSMS(而不是Tsql)仅对日志进行2次备份后,创建了一个全新的备份集,SSMS中的Shrink-Files-Log对话框终于实际工作了,释放了一些磁盘空间.

不确定为什么需要2个备份,或者为什么Tsql不起作用,并且收缩对话框中报告的“可回收空间”没有区别(第一次备份后的所有收缩尝试都是99%)也是,但仍然没有释放任何空间),但问题现在解决了.谢谢大家.

解决方法

执行事务日志备份,with whatever method you feel most comfortable with.

这将导致已从磁盘中删除已提交到数据库的事务日志.理想情况下,您应该实际创建一个数据库维护任务,以便经常性地为您执行此操作 – 正是出于这个原因 – 消除旧的事务日志,这样您就不会填满磁盘.

根据你问题的另一点……不,不是真的.是的,他们执行该功能,但不仅仅是该功能.

数据库不以其他文件的传统方式备份(或写入),因为数据库文件本身经常使用并且不断变化.因此,单个“时间点”备份要么需要使数据库脱机以将其“冻结”在一致状态,要么导致备份的不同部分包含与备份开始时不同的数据.

什么事务日志是数据库执行的每个“事务”的记录.每次更改,更新,添加,删除等记录时,不是写入数据库文件,而是将这些操作写入单独的文件,事务日志,然后在sql服务器确定安全时将其提交到数据库文件中这样做不会导致任何活动停止.因此,事务日志实际上是在数据库实际变为数据库[文件]之前进行的更改.

因此,如果您需要返回给定的数据库状态或时间点,则会“重播”事务日志.本质上,不是复制文件数据,而是访问为数据库找到的最新时间点状态,然后执行使数据库达到指定[稍后]状态的所有相同操作.但是,重要的是要注意,在任何给定时间,您的事务日志将包含尚未提交到数据库的事务.因此,它们不仅仅是执行时间点恢复的能力.它们包含正在进行的[某些]更改,或者很快将对数据库进行更改.

这就是为什么在清除事务日志之前你被迫进行备份的原因 – 一旦备份完成,系统就会有一个数据库的时间点副本,以供将来任何恢复引用,并且能够确定哪些事务有已经提交到数据库,哪些没有.使用该信息,系统知道要为您删除哪些过时的事务日志,哪些不是.

但是,这可能需要一些时间,具体取决于事务日志的大小.如果你以前从未做过一次,那么你需要一段时间.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_no='LJCG001H' THEN dbo.ELTPNAME(a.fw_nu) ELSE d.fm_name END),e.fw_state_nm,f.fw_rmk_nm
if not exists(select name from syscolumns where name='tod_no' and id=object_id('iebo09d12')) alter table iebo09d12 add tod_no varchar(
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_nm,g.fa_name from LJSS007H a (nolock) Left join LJPA002H b (nolock) On a.pa_no =b.pa_no Left jo
要在 SQL Server 2019 中设置定时自动重启,可以使用 Windows 任务计划程序。下面是详细的步骤: 步骤一:创建批处理文件 打开记事本。 输入以下内容: net stop "SQL Server (MSSQLSERVER)" net start "SQ
您收到的错误消息表明数据库 'EastRiver' 的事务日志已满,导致数据库操作失败。要解决这个问题,可以按照以下步骤操作: 1. 备份事务日志首先,备份事务日志以释放空间: BACKUP LOG [EastRiver] TO DISK = N'C:\Backup\East
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标识ID,若不知道怎么查询数据库的标识ID, 打开SQL Server management studio,点击工具。选择SQL Server Profiler。 登录,登录成功后,如果有个默认弹窗,先取消 新建追踪 命名
--最新的解决方法 --先创建用户帐户,不进行授权,然后通过下面的SQL语句将该用户帐户关联至对应的数据库用户。优点是避免了重新授权的操作。 USE tempdbEXEC sp_change_users_login 'Update_One', 'iemis', &#3
命令: ALTER TABLE 表名 add 列名 数据类型 default 默认值 not null 例如: ALTER TABLE LJEL005H add el_req int default 15 not null
declare @i int set @i=340 while @i<415 begin set @i=@iʱ insert into LJWK007H select '2024','28','9110','3PTSD621000000
alter table LJSU002H add default (0) for su_totalamt with values
命令: 有默认值时用:alter table 表名 DROP 约束 alter table 表名 DROP COLUMN 列名 例如: alter table LJEL005H DROP COLUMN el_req 注意: 如果有默认值先删除约束,否则报错: --消息 5074,级别 16,状态 1
mysql报错Unknown collation: utf8mb4_0900_ai_ci 解决方案: 将文件内的所有 utf8mb4_0900_ai_ci 换成 utf8_general_ci utf8mb4 换成 utf8
SQL SERVER根据数据表的某个栏位查询另一个数据表符合条件的某个栏位的值,如果多行则合并为一张字符串形式 要在 SQL Server 中根据一个数据表的某个列查询另一个数据表符合条件的某个列的值,并将多行结果合并为一个字符串,可以使用 FOR XML PATH 子句来执行此操作。以下是一个示例
ALTER TABLE LJPA001H DROP CONSTRAINT DF_LJPA001H_pa_sex_1 ALTER TABLE LJPA001H ALTER COLUMN pa_sex VARCHAR(1)
DATEDIFF和DATEADD函数。DATEDIFF函数计算两个日期之间的小时、天、周、月、年等时间间隔总数。DATEADD函数计算一个日期通过给时间间隔加减来获得一个新的日期。要了解更多的DATEDIFF和DATEADD函数以及时间间隔可以阅读微软联机帮助。使用DATEDIFF和DATEADD函
select top 100 substring(qr_code,8,8) ,* from [LiuJun_PKh_lcfc_hf] --where right(ri,8) or substring(qr_code,8,8)=. select top 10 left(right(one_code,1
1、发现事务日志备份突然停止了 2、查看维护计划中的事务日志设置 3、发现备份任务中,事务日志需要指向的数据库不在 4、进入数据库属性 5、在选项中将恢复模式改为“完整”
select DB_ID('SBTERPDB')
您收到的错误消息表明数据库 'EastRiver' 的事务日志已满,导致数据库操作失败。要解决这个问题,可以按照以下步骤操作: 1. 备份事务日志首先,备份事务日志以释放空间: BACKUP LOG [EastRiver] TO DISK = N'C:\Backup\East