gpt4 book ai didi

sql-server - 如何查看无法在 SQL Server 2008 R2 中修改的存储过程的定义?

转载 作者:行者123 更新时间:2023-12-03 12:42:19 28 4
gpt4 key购买 nike

我正在尝试查看驻留在 SQL Server 2008 R2 中运行的数据库中的存储过程。我在[dbName] > Programmability > Stored Procedures > dbo.[sprocName]下找到了存储过程但它旁边有一个小挂锁图标,当我右键单击它进行修改时,修改选项变灰。

然后我尝试通过查询数据库中的对象来访问定义,如下所示:

use [dbName];
select * from sys.sql_modules
where definition LIKE '%[sprocName]%'

这不会产生所需存储过程的定义,但查询确实适用于我已经可以修改的存储过程。

如何在不获得修改权限的情况下查看此存储过程的定义?

更新

看来 Sproc 实际上是根据此错误消息加密的:
TITLE: Microsoft SQL Server Management Studio
------------------------------

Script failed for StoredProcedure 'dbo.[sprocName]'. (Microsoft.SqlServer.Smo)

------------------------------
ADDITIONAL INFORMATION:

Property TextHeader is not available for StoredProcedure '[dbo].[sprocName]'. This property may not exist for this object, or may not be retrievable due to insufficient access rights.
The text is encrypted. (Microsoft.SqlServer.Smo)

最佳答案

为了做到这一点,您需要拥有所有必要的权限(基本上是 SA),但您应该可以关注以下站点来解决问题。

http://sqljunkieshare.com/2012/03/07/decrypting-encrypted-stored-procedures-views-functions-in-sql-server-20052008-r2/

关于sql-server - 如何查看无法在 SQL Server 2008 R2 中修改的存储过程的定义?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17432585/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com