怎样获取某个数据库的所有存储过程SQL语句
创始人
2024-07-30 22:50:54
0

最近公司做了一个项目,并且该项目目前已投入使用。现在数据库挂在客户的服务器上。由于还有一部分功能不是很完善,需要经常更新他们的存储过程。

由于更新的存储过程有些多,而且到后来经常不知道哪些存储过程是 已经修改过的,哪些是新增加的。我就想到了一个法子。那就是以文本方式获取我本地服务器上的所有存储过程,然后执行文本统一更新至客户服务器上。

具体实现如下,如下语句执行后,会在查询分析器执行消息中显示执行数据库的所有存储过程源码,直接复制保存文本即可。

  1. declare @proc_text varchar(max)  
  2. DECLARE get_proc_text_cursor CURSOR FOR 
  3. SELECT  'if object_id(N'''+ [name] +''') is not null drop proc ' + [name] +  CHAR(10) +  CHAR(13)  +  '  GO '  +  CHAR(10) +  CHAR(13) + definition + CHAR(10)  + CHAR(13) +' GO'   
  4. FROM sys.sql_modules  
  5. inner join sysobjects  on sys.sql_modules.object_id = sysobjects.id  and type='p' 
  6.  
  7. OPEN get_proc_text_cursor  
  8.  
  9. FETCH NEXT FROM get_proc_text_cursor  
  10. INTO @proc_text  
  11.  
  12. WHILE @@FETCH_STATUS = 0  
  13. BEGIN 
  14.  
  15. print @proc_text  
  16.     FETCH NEXT FROM get_proc_text_cursor  
  17.     INTO @proc_text  
  18. END 
  19. CLOSE get_proc_text_cursor  
  20. DEALLOCATE get_proc_text_cursor 

【编辑推荐】

 

  1. 淘宝海量数据库之克服随机IO难题
  2. 数据库如何抵抗随机IO的问题、方法与现实
  3. 一步一步设计你的数据库之不可轻视的需求分析
  4. 养成一个SQL好习惯带来一笔大财富

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...