查找sql server 2014存储过程是否包含某个关键字

在 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只找出两条记录,不知道是什么原因

关键说明

  1. 关键字替换 :将代码中的 N'你的关键字' 替换为你要查找的内容(比如 N'UserID'N'GetData' 等),前缀 N 表示 Unicode 字符,避免中文等特殊字符检索异常。
  2. 大小写问题 :默认情况下,SQL Server 的 LIKE 操作符是否区分大小写取决于数据库的排序规则(Collation)。如果需要强制不区分大小写,可以修改 WHERE 条件:
sql 复制代码
AND LOWER(m.definition) LIKE '%' + LOWER(@SearchKeyword) + '%'
相关推荐
阿波罗尼亚4 小时前
数据库序列(Sequence)
数据库
Junsir大斗师4 小时前
Nginx服务器代理Postgresql-16后端数据库
数据库·nginx
Je1lyfish4 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
m0_596749096 小时前
如何防止SQL拼接漏洞_使用PDO对象实现安全的SQL交互
jvm·数据库·python
老纪的技术唠嗑局7 小时前
深度解析 LLM Wiki / Obsidian-Wiki / GBrain:Agent 时代知识的“自组织”与“自进化”
大数据·数据库·人工智能·算法
2301_795099749 小时前
golang如何在Gin中自定义验证器_golang Gin自定义验证器实现方法
jvm·数据库·python
2301_766283449 小时前
如何在MongoDB GridFS中进行按文件大小(length)范围的查询
jvm·数据库·python
萧曵 丶10 小时前
MySQL 高频面试题(由浅到深 完整版,面试必背)
数据库·mysql·面试
czlczl2002092510 小时前
MySQL 执行引擎:排序与临时表机制深度解析
数据库·mysql
lifewange11 小时前
DBeaver如何安装
数据库