首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在SQL Server数据库中搜索字符串?

如何在SQL Server数据库中搜索字符串?
EN

Stack Overflow用户
提问于 2012-02-08 07:50:12
回答 8查看 450.3K关注 0票数 129

我知道这是可能的,但我不知道怎么做。

我需要在SQL Server数据库中搜索特定字符串的所有提法。

例如:我想搜索所有的表,视图,函数,存储过程,...对于字符串"tblEmployes“(不是表中的数据)。

我需要这样做的原因之一是我想删除一些额外创建的数据表,但我担心它们可能在过程或函数中的某个地方使用。

EN

回答 8

Stack Overflow用户

发布于 2013-03-13 11:33:38

你也可以试试ApexSQL Search --它是一个类似于SQL Search的免费SSMS插件。

如果您真的只想使用SQL,则可能需要尝试以下脚本:

代码语言:javascript
复制
select
S.name as [Schema],
o.name as [Object],
o.type_desc as [Object_Type],
C.text as [Object_Definition]
from sys.all_objects O inner join sys.schemas S on O.schema_id = S.schema_id
inner join sys.syscomments C on O.object_id = C.id
where S.schema_id not in (3,4) -- avoid searching in sys and INFORMATION_SCHEMA schemas
and C.text like '%ICE_%'
order by [Schema]
票数 49
EN

Stack Overflow用户

发布于 2012-12-17 16:52:36

您可以将数据库(如果较小)导出到硬盘/桌面,然后只需通过文本搜索程序或文本编辑器进行字符串搜索。

票数 27
EN

Stack Overflow用户

发布于 2012-02-08 07:54:13

要在SQL Server中按名称获取表:

代码语言:javascript
复制
SELECT *
FROM sys.Tables
WHERE name LIKE '%Employees%'

要按名称查找存储过程:

代码语言:javascript
复制
SELECT name
FROM sys.objects
WHERE name = 'spName'

要获取与表相关的所有存储过程:

代码语言:javascript
复制
----Option 1
SELECT DISTINCT so.name
FROM syscomments sc
INNER JOIN sysobjects so ON sc.id=so.id
WHERE sc.TEXT LIKE '%tablename%'
----Option 2
SELECT DISTINCT o.name, o.xtype
FROM syscomments c
INNER JOIN sysobjects o ON c.id=o.id
WHERE c.TEXT LIKE '%tablename%'
票数 17
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9185871

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档