• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    一次性压缩Sqlserver2005中所有库日志的存储过程
    有没有办法更快一点?
    有没有办法一次性收缩所有数据库?
    复制代码 代码如下:

    alter database 数据库名
    set recovery simple
    go
    dbcc shrinkdatabase (数据库名)
    go
    alter database 数据库名
    set recovery full
    go

    目前也有压缩日志的工具,一个B/S界面形式的操作压缩数据库的,就是在选择数据库的时候老需要重新去选择具体的库,而且数据库数量很大的时候,有些库被压缩了,并没有自动排序; 目前需要的是被压缩后的数据库自动滚到最后面,每次下拉列表中打开的始终是日志记录容量最大的那个库,这个容易实现,要求就是执行日志压缩的时候,执行速度要快些?
    如何优化?有没有办法一次性压缩所有的库?
    通过存储过程实现,一次性压缩所有数据库:在Sqlserver2005中测试通过
    复制代码 代码如下:

    create procedure shrinkDatabase
    as
    declare @name nvarchar(2000)
    declare getDataBaseCursor cursor for
    select name from sysdatabases //取出所有库名
    open getDataBaseCursor
    fetch next from getDataBaseCursor
    into @name //将取出来的值放在一个变量中
    while @@fetch_status=0 //根据值循环执行压缩
    begin
    exec ('alter database '+ @name+' set recovery simple')
    exec ('dbcc shrinkdatabase('+@name+')')
    exec ('alter database'+@name+' set recovery full')
    fetch next from getDataBaseCursor
    into @name end
    close getDataBaseCursor //关闭
    deallocate getDataBaseCursor //释放
    sp_helpdb urltest //比对数据库大小
    exec shrinkDatabase //执行
    您可能感兴趣的文章:
    • 使用sqlserver存储过程sp_send_dbmail发送邮件配置方法(图文)
    • sqlserver2005利用临时表和@@RowCount提高分页查询存储过程性能示例分享
    • sqlserver2008查看表记录或者修改存储过程出现目录名无效错误解决方法
    • sqlserver 存储过程中If Else的用法实例
    • .net下调用sqlserver存储过程的小例子
    • SqlServer获取存储过程返回值的实例
    • sqlserver 各种判断是否存在(表名、函数、存储过程等)
    • sqlserver 存储过程带事务 拼接id 返回值
    • SqlServer存储过程实现及拼接sql的注意点
    • SQLServer存储过程中事务的使用方法
    • 获取SqlServer存储过程定义的三种方法
    上一篇:EXEC(EXECUTE)函数访问INSERTED或DELETED的内部临时触发表
    下一篇:SQL优化基础 使用索引(一个小例子)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    一次性压缩Sqlserver2005中所有库日志的存储过程 一次性,压缩,Sqlserver2005,