知识大全 分享两条Delphi开发经验[2]

Posted 文件

篇首语:勤劳一日,可得一夜安眠;勤劳一生,可得幸福长眠。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 分享两条Delphi开发经验[2]相关的知识,希望对你有一定的参考价值。

经验技巧:分享两条Delphi开发经验[2]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

   清空数据库的日志文件

  问题的引出 我们的切割过程就是将单据数据中某个日期以前的数据先复制到新的数据库中(select into ) 然后再将原来数据库中的这些数据删除 这样操作在数量量很大的数据库上时 其日志文件的增长也是惊人的 我复制一个 万条记录的表时 最后发现仅这一个表的操作就使新数据库的日志文件增加了 MB 如果不加清理 那就会被日志文件占用大量宝贵的磁盘空间 况且 我们转移到的新建数据库的作用也只是用来查询 以后不会有任何Insert Update Delete操作的 要这些日志文件没有什么用处 因此必须在向它转移数据的过程中做一些缩小日志文件的处理 怎么办??问题由此而生

  ( )处理过程中不记录日志

  设置方法如下 企业管理器中打开对应数据库的 属性 页框 选项 中将 模型 改为 简单 这样设置的结果是对此数据库的任何操作都将不记录事务日志 对应的SQL为 EXEC sp_dboption @pdbName trunc log on cpt TRUE

  但是 我们经过测试发现 启用此功能后 我们在对这个数据库操作时 就不能用事务操作了 程序执行到BeginTranSaction时就报错 不能执行下去 由于我们不能在对此库的操作中保证 %的正确性 因此我们还需要事务 因此这种方法适用空间有限 也不能满足我们程序的需求

  我们还得继续查找

  ( )处理过程中允许记录日志 但要对日志文件进行处理 时时缩小它

  SQL Server的联机帮助告诉我们

  在下列情况下 日志文件的物理大小将减少

  执行 DBCC SHRINKDATABASE 语句时

  执行引用日志文件的 DBCC SHRINKFILE 语句时

  自动收缩操作发生时

  下面我们逐个分析这三个方案

  ① DBCC SHRINKDATABASE 收缩特定数据库的所有数据和日志文件 包含我们的需求 但也大于我们的需求 此方案可用 但不要着急 给人的感觉是买了一件能穿的衣服 但尺寸大了些 穿在身上有点不舒服 我们接着分析以下两个方案

  ② DBCC SHRINKFILE: 收缩相关数据库的指定数据文件或日志文件大小 与方案 的区别仅一字之差 和 与 或 相当于把方案 拆成两步来执行 我们需要的就是收缩日志文件 因此 它对我们来说显得比较合适 有点量体裁衣的感觉 但还有没有更好的呢 我们来看第三个方案

  ③自动收缩 数据库也可设置为按给定的时间间隔自动收缩 服务器定期检查每个数据库中的空间使用情况 如果发现数据库中有大量闲置空间 而且它的 autoshrink 选项设置为 true SQL Server 就缩小该数据库中的文件大小 它是周期性的执行DBCC SHRINKDATABASE 既然方案 已经是一件尺寸大了一些的衣服 则此方案就相当于又穿上了N件大尺寸衣服 一件就已经够了 我还要那么多干嘛呢??

  综合对比发现 方案 正是我们需要的

  DBCC SHRINKFILE ( +Trim(edDBMC Text)+ _Log TRUNCATEONLY)

  经过这个语句处理以后 日志文件将回到它的最小状态 KB 任何的日志记录都将清空

  再结合我们的工具 复制完一个表之后 我们就执行方案 处理过程中日志文件暂时占用的最大空间也就是处理最大数据表时产生的日志空间 但最后都将清空 显示为 多KB 相对于庞大的数据文件而言 微之戡微

cha138/Article/program/Delphi/201311/24748

相关参考

知识大全 浅谈Delphi开发经验[2]

浅谈Delphi开发经验[2]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  有经验的程序员完成

知识大全 浅谈Delphi开发经验[1]

浅谈Delphi开发经验[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  Delphi是一个

知识大全 Delphi开发经验四则

Delphi开发经验四则  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  配置数据引擎(BDESQ

知识大全 用Delphi 开发数据库程序经验三则

用Delphi开发数据库程序经验三则  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  建立临时表 

知识大全 用Delphi开发数据库程序经验三则

用Delphi开发数据库程序经验三则  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!一建立临时表  

知识大全 Delphi自定义部件开发(一)[2]

DELPHI基础教程:Delphi自定义部件开发(一)[2]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看

知识大全 Delphi自定义部件开发(二)[2]

DELPHI基础教程:Delphi自定义部件开发(二)[2]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看

知识大全 Delphi自定义部件开发(三)[2]

DELPHI基础教程:Delphi自定义部件开发(三)[2]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看

知识大全 Delphi自定义部件开发(四)[2]

DELPHI基础教程:Delphi自定义部件开发(四)[2]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看

知识大全 开发Delphi对象式数据管理功能(一)[2]

DELPHI基础教程:开发Delphi对象式数据管理功能(一)[2]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快