如何快速查找使用了某个字段的所有存储过程

 我来答
huanglenzhi
2015-01-21 · 知道合伙人数码行家
huanglenzhi
知道合伙人数码行家
采纳数:117538 获赞数:517174
长期从事计算机组装,维护,网络组建及管理。对计算机硬件、操作系统安装、典型网络设备具有详细认知。

向TA提问 私信TA
展开全部

  当一个系统中使用了很多的表,并且存在大量的存储过程,当数据库中的某个表删除了某个字段,那么相应的存储过程也需要改动,但是我们不知道哪些存储过程使用了该字段,那我们该怎么办?我们可以从之前的文档一个一个查找使用了该字段的存储过程,但是这样效率很多,而且还容易出错,我们可以使用下面的方法来查找所有使用了某个字段的存储过程。如下的函数:


  [sql] view plaincopyprint?

  01.GO

  02.SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容

  03.FROM syscomments sc

  04.INNER JOIN sysobjects obj ON sc.Id = obj.ID

  05.WHERE sc.TEXT LIKE '%' + '字段名' + '%'

  06.AND TYPE = 'P'

  07.GO

  GO

  SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容

  FROM syscomments sc

  INNER JOIN sysobjects obj ON sc.Id = obj.ID

  WHERE sc.TEXT LIKE '%' + '字段名' + '%'

  AND TYPE = 'P'

  GO


  下面举一个例子,比如查找数据库中所有使用了AdId这个字段的所有存储过程。


  


  [sql] view plaincopyprint?

  01.USE KyCms

  02.GO

  03.SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容

  04.FROM syscomments sc

  05.INNER JOIN sysobjects obj ON sc.Id = obj.ID

  06.WHERE sc.TEXT LIKE '%' + 'AdID' + '%'

  07.AND TYPE = 'P'

  08.GO

  USE KyCms

  GO

  SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容

  FROM syscomments sc

  INNER JOIN sysobjects obj ON sc.Id = obj.ID

  WHERE sc.TEXT LIKE '%' + 'AdID' + '%'

  AND TYPE = 'P'

  GO

沫神钢虚1F
2017-01-12 · TA获得超过2.4万个赞
知道大有可为答主
回答量:1.6万
采纳率:59%
帮助的人:1102万
展开全部
通过下面的SQL,我们可以快速查看某个存储过程执行的状况:
  SELECT TOP 100 db_name(d.database_id) as DBName,s.name as 存储名称,s.type_desc as 存储类型,d.cached_time as SP添加到缓存的时间,
  d.last_execution_time as 上次执行SP的时间,d.last_elapsed_time as [上次执行SP所用的时间(微妙)],d.total_elapsed_time as [完成此SP的执行所用的总时间(微妙)],
  d.total_elapsed_time/d.execution_count as [平均执行时间(微妙)],d.execution_count as 自上次编译以来所执行的次数
  FROM SYS.procedures S JOIN SYS.dm_exec_procedure_stats D
  ON S.object_id=D.object_id
  WHERE S.NAME='SP_Name'
  ORDER BY D.total_elapsed_time/D.execution_count DESC
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式