网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > SQL技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.PL/SQL开发中动态SQL的使用方法.
.SQL Server 2000中生成XML的小技.
.怎样将Excel中的数据导入到SQLSe.
.把SQL结果中几行值串起来的sum_s.
.SQL SERVER数据导成INSERT.
.sql 事件探查器方案.
.pl/sql developer中TIMESTAMP的显.
.初学者必读:精讲SQL中的时间计算.
.只让指定的机器连接SQLServer服务.
.关于sql server下无限多级别分类.
.一些有用的sql语句实例.
.SQL分页算法,还可以更好 .
.SQL Server 2000的数据转换服务(.
.SQL Server 2005 读取xml 文件 突.
.如何将数据仓库与系统体系结构合.
.SQL Server数据库性能的优化.
.巧用数据库引擎优化Tuning Advis.
.经验总结:SQL Server与Oracle的.
.讲解SQL Server2005数据项的分拆.
.列出SQL SERVER 所有表,字段名,.

自动备份SQL Server数据库中用户创建的Stored Procedures

发表日期:2006-4-18


    为了避免意外丢失/损坏辛苦创建的Stored Procedures,或者想恢复到以前版本的Stored Procedures,这样提供了一个有效方法,可以自动将指定数据库中的Stored Procedures进行备份。

 

1. 在特定的数据库(建议为SQL Server的master数据库)上创建数据表StoredProceduresBackup,用来保存备份的Stored Procedures。

IF OBJECT_ID('StoredProceduresBackup') IS NOT NULL

 

DROP TABLE StoredProceduresBackup

GO

 

CREATE TABLE StoredProceduresBackup

(

   AutoID INTEGER IDENTITY(1,1) PRIMARY KEY,

   InsertDate DATETIME DEFAULT GETDATE(),

   DatabaseName VARCHAR(50),

   ProcedureName VARCHAR(50),

   ProcedureText VARCHAR(4000)

)

GO

 

2. 创建Stored Procedure名为usp_ProceduresVersion,该Stored Procedure用来将需要备份Stored Procedures的备份到上述创建的数据表中。

  其中主要访问sysobjects和syscomments系统表:

(1) sysobjects system table
Contains one row for each object (constraint, default, log, rule, stored procedure, and so on) created within a database. In tempdb only, this table includes a row for each temporary object.

 

(2) syscomments system table
Contains entries for each view, rule, default, trigger, CHECK constraint, DEFAULT constraint, and stored procedure. The text column contains the original SQL definition statements, which are limited to a maximum size of 4 MB. This table is stored in each database.

 

(3) source script of stored procedure.

 

/*

Name:  usp_ProceduresVersion

Description:  Back up user defined stored-procedures

Author:  Rickie

Modification Log: NO

 

Description                        Date     Changed By

Created procedure            8/27/2004           Rickie

*/

 

CREATE PROCEDURE usp_ProceduresVersion @DatabaseName NVARCHAR(50)

AS

SET NOCOUNT ON

 

--This will hold the dynamic string.

DECLARE @strSQL NVARCHAR(4000)

 

--Set the string

--Only stored procedures

SET @strSQL = 'INSERT INTO master.dbo.StoredProceduresBackup(

            DatabaseName,ProcedureName,ProcedureText )

SELECT ''' + @DatabaseName + ''', so.name, sc.text

FROM ' + @DatabaseName + '.dbo.sysobjects so

INNER JOIN ' + @DatabaseName + '.dbo.syscomments sc

ON so.id = sc.id

WHERE so.type = ''p''' + ' and so.status>0

Order By so.id '

 

--Execute the string

EXEC dbo.sp_executesql @strSQL

GO

 

3. 创建Job执行上述Stored Procedure

在SQL Server上创建Job,并设定运行计划,这样指定数据库的Stored Procedures就可以自动备份到上述数据表中。


OK. That’s all.  Any questions about it, please contact me at rickieleemail@yahoo.com. Have a good luck.

上一篇:如何将SQL Server表驻留内存和检测 人气:6468
下一篇:SQL Script tips for MS SQL Server 人气:6671
浏览全部SQL Server的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐