在 SQL Server 2014 中查找所有包含特定关键字的存储过程,这个需求在日常数据库维护和代码检索中非常常见。
方法 1:查询系统视图(推荐)
这是最通用、性能较好的方法,通过查询 sys.procedures(存储过程元数据)和 sys.sql_modules(存储过程定义文本)来实现:
sql
-- 替换这里的 '你的关键字' 为实际要查找的内容
DECLARE @SearchKeyword NVARCHAR(100) = N'你的关键字';
-- 核心查询
SELECT
SCHEMA_NAME(p.schema_id) AS [架构名],
p.name AS [存储过程名],
m.definition AS [存储过程完整定义],
p.create_date AS [创建时间],
p.modify_date AS [最后修改时间]
FROM
sys.procedures p
INNER JOIN
sys.sql_modules m ON p.object_id = m.object_id
WHERE
-- 不区分大小写查找包含关键字的存储过程
m.definition LIKE '%' + @SearchKeyword + '%'
-- 可选:只查找特定架构下的存储过程,比如 dbo
-- AND SCHEMA_NAME(p.schema_id) = 'dbo'
ORDER BY
p.modify_date DESC;
实例:

方法 2:使用 INFORMATION_SCHEMA 视图(兼容性更好)
如果你需要兼容更多 SQL Server 版本,可以使用 INFORMATION_SCHEMA 视图:
sql
-- 替换这里的 '你的关键字' 为实际要查找的内容
DECLARE @SearchKeyword NVARCHAR(100) = N'你的关键字';
SELECT
ROUTINE_SCHEMA AS [架构名],
ROUTINE_NAME AS [存储过程名],
ROUTINE_DEFINITION AS [存储过程定义],
CREATED AS [创建时间],
LAST_ALTERED AS [最后修改时间]
FROM
INFORMATION_SCHEMA.ROUTINES
WHERE
ROUTINE_TYPE = 'PROCEDURE' -- 只筛选存储过程(排除函数)
AND ROUTINE_DEFINITION LIKE '%' + @SearchKeyword + '%'
ORDER BY
LAST_ALTERED DESC;
方法2只找出两条记录,不知道是什么原因
关键说明
- 关键字替换 :将代码中的
N'你的关键字'替换为你要查找的内容(比如N'UserID'、N'GetData'等),前缀N表示 Unicode 字符,避免中文等特殊字符检索异常。 - 大小写问题 :默认情况下,SQL Server 的
LIKE操作符是否区分大小写取决于数据库的排序规则(Collation)。如果需要强制不区分大小写,可以修改 WHERE 条件:
sql
AND LOWER(m.definition) LIKE '%' + LOWER(@SearchKeyword) + '%'
