找回密码
 注册账号

QQ登录

只需一步,快速开始

手机号码,快捷登录

手机号码,快捷登录

初学者课程:T3自学|T6自学|U8自学软件下载课件下载工具下载资料:通资料|U8资料|NC|培训|年结积分规则 | 使用常见问题Q&A
知识库:U8 | | NC | U9 | OA | 政务U8|U9|NCC|NC65|NC65客开|NCC客开新手必读 | 任务 | 快速增金币用友QQ群[微信群]
查看: 4915|回复: 9

[政务] 关于数据库日志的清除问题

  [复制链接]
发表于 2011-11-3 09:18:46 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册账号

×

公司的数据库大太了,硬盘没空间了,现在要新建账套都新建不了,怎么办?

我试了从后台删除日志,然后进账套清除操作日志,这好像对数据库文件的大小没影响。


求高人指点操作数据库日志文件的方法:
发表于 2011-11-3 10:01:17 | 显示全部楼层
收缩数据库               
发表于 2011-11-3 10:39:51 | 显示全部楼层
      [1。凡事弄数据你都先备份,你别管它是嘛~~(备份你会的吧。。。。)
  2。打开你的[查询分析器]--选择好你要减肥的数据库名称
  3。运行代码:DUMP TRANSACTION [你要减肥的数据库名字] WITH NO_LOG(作用:清空日志)
  4。运行代码:BACKUP LOG [你要减肥的数据库名字] WITH NO_LOG(作用:截断事务日志)
  5。运行代码:DBCC SHRINKDATABASE([你要减肥的数据库名字])(作用:收缩数据库文件(如果不压缩,数据库的文件不会减小))
  6。运行代码:DBCC UPDATEUSAGE (你要减肥的数据库名字) (作用:报告和更正 sysindexes 表的不正确内容) ]
    1、清空日志
DUMP  TRANSACTION  库名  WITH NO_LOG
2、截断事务日志
BACKUP LOG 数据库名 WITH NO_LOG  
3、收缩数据库文件(如果不压缩,数据库的文件不会减小)
企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件
--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。
--选择数据文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。
也可以用SQL语句来完成:
--收缩数据库
DBCC SHRINKDATABASE(客户资料)
--收缩指定数据文件,1是文件号,可以通过这个语句查询到:
select * from sysfiles DBCC SHRINKFILE(1)
4、为了最大化的缩小日志文件(如果是sql 7.0,这步只能在查询分析器中进行)
a.分离数据库:
企业管理器--服务器--数据库--右键--分离数据库
b.在我的电脑中删除LOG文件
c.附加数据库:
企业管理器--服务器--数据库--右键--附加数据库
此法将生成新的LOG,大小只有500多K
或用代码:
下面的示例分离 pubs,然后将 pubs 中的一个文件附加到当前服务器。
a.分离
EXEC sp_detach_db @dbname = 'pubs'
b.删除日志文件
c.再附加:
EXEC sp_attach_single_file_db @dbname = 'pubs', @physname = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf'
5、为了以后能自动收缩,做如下设置:
企业管理器--服务器--右键数据库--属性--选项--选择“自动收缩”
--SQL语句设置方式:
EXEC sp_dboption '数据库名', 'autoshrink', 'TRUE'
6、如果想以后不让它日志增长得太大。
企业管理器--服务器--右键数据库--属性--事务日志
--将文件增长限制为xM(x是你允许的最大数据文件大小)
--SQL语句的设置方式:
alter database 数据库名 modify file(name=逻辑文件名,maxsize=20)   
发表于 2011-11-3 10:44:28 | 显示全部楼层
这是在网上学来的。
 楼主| 发表于 2011-11-3 11:23:09 | 显示全部楼层
谢了,我执行了一个SQL脚本,DATA文件夹瞬间从近150G缩小到了15G;希望不会问题才行;


脚本也是我在这坛子里下的


脚本如下:

DECLARE @DBNAME VARCHAR(40)
SELECT @DBNAME='pubs'




IF @DBNAME  IN (SELECT NAME FROM MASTER.DBO.SYSDATABASES WHERE DBID>4)
        BEGIN
                EXEC (' use master Dump transaction  '+@DBNAME+ '  with no_log  ')
                EXEC (' use '+ @DBNAME+ '  DBCC SHRINKFILE (2)  ')
                PRINT 'OK'
        END
ELSE
        PRINT '数据库名称输入错误,请修改数据库名称'*/


/*收缩所有用户数据库*/

DECLARE cur_dbname CURSOR
   FOR
   SELECT NAME FROM MASTER.DBO.SYSDATABASES WHERE DBID>4
OPEN cur_dbname
DECLARE @dbname char(30)

FETCH NEXT FROM cur_dbname INTO @dbname
WHILE (@@FETCH_STATUS <> -1)
BEGIN

     PRINT @dbname
     EXEC (' use master Dump transaction  '+@DBNAME+ '  with no_log  ')
     EXEC (' use '+ @DBNAME+ '  DBCC SHRINKFILE (2)  ')
     PRINT 'OK'

     FETCH NEXT FROM cur_dbname INTO @dbname
END
CLOSE cur_dbname
DEALLOCATE cur_dbname
GO




本来我是选 定一个数据库先操作的,但没仔细看脚本的内容;结果整库全收缩了
发表于 2011-11-3 22:24:28 | 显示全部楼层
不要一直想着把数据库缩小,做些简单的收缩或删日志后就行了,不要弄得那么复杂,要换个思路,不是没空间吗?就换个大空间的分区或再挂一个硬盘,直接把数据库分离后复制过去再附加就OK了
发表于 2012-5-10 01:48:27 | 显示全部楼层
楼主,你那段SQL脚本有木有问题喔?希望回复下,没问题就试啦,现正愁这问题呢
回复 点赞 拍砖

使用道具 举报

发表于 2012-5-10 09:51:19 | 显示全部楼层
各位真是高手啊
回复 点赞 拍砖

使用道具 举报

发表于 2012-6-14 11:50:47 | 显示全部楼层
好东东,又学到一些知识。
回复 点赞 拍砖

使用道具 举报

发表于 2012-7-2 23:48:43 | 显示全部楼层
在网上学来的
回复 点赞 拍砖

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号

本版积分规则

QQ|站长微信|Archiver|手机版|小黑屋|用友之家 ( 蜀ICP备07505338号|51072502110008 )

GMT+8, 2024-5-30 01:26 , Processed in 0.052812 second(s), 9 queries , Gzip On, Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表