压缩日志及数据库文件大小/*--特别注意请按步骤进行,未进行前面的步骤,请不要做后面的步骤
否则可能损坏你的数据库.
一般不建议做第4,6两步
第4步不安全,有可能损坏数据库或丢失数据
第6步如果日志达到上限,则以后的数据库处理会失败,在清理日志后才能恢复.
--*/--下面的所有库名都指你要处理的数据库的库名1.清空日志
DUMP  TRANSACTION  库名  WITH  NO_LOG    2.截断事务日志:
BACKUP LOG 库名 WITH NO_LOG3.收缩数据库文件(如果不压缩,数据库的文件不会减小
企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件
--选择日志文件--在收缩方式里选择收缩至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 = '库名'b.删除日志文件c.再附加
EXEC sp_attach_single_file_db @dbname = '库名', 
   @physname = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\库名.mdf'5.为了以后能自动收缩,做如下设置:
企业管理器--服务器--右键数据库--属性--选项--选择"自动收缩"--SQL语句设置方式:
EXEC sp_dboption '库名', 'autoshrink', 'TRUE'6.如果想以后不让它日志增长得太大
企业管理器--服务器--右键数据库--属性--事务日志
--将文件增长限制为xM(x是你允许的最大数据文件大小)--SQL语句的设置方式:
alter database 库名 modify file(name=逻辑文件名,maxsize=20)

解决方案 »

  1.   

    3.收缩数据库文件(如果不压缩,数据库的文件不会减小
    企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件
    --选择数据文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了--收缩数据库
    DBCC SHRINKDATABASE(库名)
    5.为了以后能自动收缩,做如下设置:
    企业管理器--服务器--右键数据库--属性--选项--选择"自动收缩"
      

  2.   

    2G 现在5G
    =========>
    DBCC SHRINKDATABASE( database_name,2500)
      

  3.   

    一个数据库正常是2G 现在5G=======>
    你是什么意思,正常2G?,现在5G又是?,你分别写出你是怎样查到的数据?
      

  4.   

    你分别选择压缩数据库文件和数据库日志文件 SQL自己会报告出压缩后最小值 是多少就是多少了
      

  5.   

    我觉得里面有表有异常情况,我就想问问 怎么查这个方面,比如说我如何用SQL语句查询里面最大的表
      

  6.   

    sp_spaceused @updateusage = 'TRUE' 就是更新系统表信息 
    or
    dbcc updateusage
      

  7.   

    sp_spaceused @updateusage = 'TRUE' 这个语句只能查到这个:THIS4 5444.88 MB 146.98 MB
    reserved              data           index_size    unused
    5424024 KB 1047264 KB 186832 KB 4189928 KB但是具体查不到那个表
      

  8.   

    If Exists(Select 1 From sysobjects where name = 'get_tableinfo' and xtype = 'p')
    drop proc get_tableinfo
    goCREATE PROCEDURE get_tableinfo AS set nocount on
    if not exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[tablespaceinfo]') and OBJECTPROPERTY(id, N'IsUserTable') = 1) 
    create table  tablespaceinfo                         --创建结果存储表 
                  (Name varchar(50) ,  
                   Rows int , reserved varchar(20) ,  
                   Data varchar(20)  ,  
                   index_size varchar(20) ,  
                   Unused varchar(20) ) 
    truncate table  tablespaceinfo --清空数据表 declare @tablename varchar(255)  --表名称 declare @cmdsql varchar(500) DECLARE Info_cursor CURSOR FOR  
    select o.name   
    from dbo.sysobjects o where xtype = 'u' order by o.name OPEN Info_cursor FETCH NEXT FROM Info_cursor  
    INTO @tablename  WHILE @@FETCH_STATUS = 0 
    BEGIN   if exists (select * from dbo.sysobjects where id = object_id(@tablename) and OBJECTPROPERTY(id, N'IsUserTable') = 1) 
      execute sp_executesql  
             N'insert into tablespaceinfo  exec sp_spaceused @tbname', 
              N'@tbname varchar(255)', 
              @tbname = @tablename   FETCH NEXT FROM Info_cursor  
      INTO @tablename  
    END CLOSE Info_cursor 
    DEALLOCATE Info_cursor 
    set nocount off
    GO --执行存储过程 
    exec get_tableinfo --查询运行该存储过程后得到的结果 Select 
    Name 表名,
    Rows 行数,
    str(cast(replace(reserved,'KB','') as int) / 1024.00,7,2) + 'Mb' 表保留的空间总量,
    str(cast(replace(Data,'KB','')as int) / 1024.00,7,2) + 'Mb' 表中的数据所使用的空间量,
    str(cast(replace(index_size,'KB','')as int) / 1024.00,7,2) + 'Mb' 表中的索引所使用的空间量,
    str(cast(replace(Unused,'KB','')as int) / 1024.00,7,2) + 'Mb' 表中未用的空间量
    from tablespaceinfo
    order by 3 desc
      

  9.   

    把数据库设为单用户模式:
    DBCC CHECKDB('数据库名',REPAIR_REBUILD)
      

  10.   

    上面shuiniu(飞扬的梦)(我是一头只吃西红柿的水牛)  我执行了你的命令 但是 什么也没有得到  比较的郁闷
      

  11.   

    压缩数据库
    先执行 dbcc updateusage (0)
    再执行 sp_spaceused
    是多大就多大了
    再讨论也就这样了
      

  12.   

    DECLARE @chvSqlCmd varchar(8000)
    SET @chvSqlCmd=''
    SELECT @chvSqlCmd=@chvSqlCmd+'SELECT '''+NAME+''',COUNT(*) FROM '+NAME+CHAR(13)+'UNION'+CHAR(13)
    FROM DBO.SYSOBJECTS WHERE XTYPE='U' AND NAME!='dtproperties'
    SET @chvSqlCmd=SubString(@chvSqlCmd,1,len(@chvSqlCmd)-7)  
    --The 7 is len('UNION'+char(13),+char(13))
    EXEC (@chvSqlCmd)