网络编程
位置:首页>> 网络编程>> 数据库>> 使用SQL Server 2008中对象相关性(2)

使用SQL Server 2008中对象相关性(2)

作者:包春林 来源:IT专家网 发布时间:2008-12-12 06:36:00 

标签:SQL,Server,2008,对象,SQL

下边的脚本使用表值函型数sys.dm_sql_referenced_returns寻找所有引用SalesHistory表的对象。这一查询不但返回SalesHistory表的引用,还包含被引用的SalesHistory表中的字段。值得注意的是CROSS APPLY操作符的使用,这是因为实体是表值型函数,而且在将字段值赋予表值型函数时需要APPLY操作符。还要注意,如果遇到引用一个不存在的实体字段, 对sys.dm_referenced_entities函数的调用会出错:



  SELECT ReferencedEntityName = o.name, g.referenced_entity_name, referenced_minor_name
  FROM sys.objects o

  JOIN sys.schemas s on o.schema_id = s.schema_id

  CROSS APPLY sys.dm_sql_referenced_entities(s.name + '.' + o.name, 'OBJECT') g

  WHERE referenced_entity_name = 'SalesHistory'


在下边的脚本中,创建了一个新的名称为usp_GetSalesFromArchive的存储的过程,该过程引用不存在的SalesHistoryArchive 表



   CREATE PROCEDURE usp_GetSalesFromArchive
  (

  @Product VARCHAR(10)

  )

  AS

  BEGIN

  SELECT COUNT(SaleArchiveID) AS SalesCount, SUM(SaleArchivePrice) AS SalesAmount

  FROM dbo.SalesHistoryArchive sh

  END


现在可以利用 sys.sql_expression_dependencies系统视图寻找引用SalesHistoryArchive 表的任何对象。

或者,可以稍微改变该查询来寻找存储的过程usp_GetSalesFromArchive引用的表.



  SELECT ReferencingObject = o.name ,
  ReferencedObject = d.referenced_entity_name

  FROM sys.sql_expression_dependencies d

  join sys.objects o on d.referencing_id = o.object_id

  WHERE o.name = 'usp_GetSalesFromArchive'


结论

通过对象名称而不是对象ID跟踪相关性拥有诸多好处。用户可能喜欢寻找存储的过程,该过程引用并不存在的对象,因为这帮助用户寻找不再使用或需要更新的任何存储的过程。

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com