gpt4 book ai didi

sql server 2008 - 查找哪些表包含特定文本

转载 作者:行者123 更新时间:2023-12-01 09:38:06 25 4
gpt4 key购买 nike

我有一个包含几百个表的数据库

我需要在所有表的任何列中找到一个特定的字符串。

我将如何解决这个问题>??

最佳答案

查找表列使用:

SELECT table_name=sysobjects.name,
column_name=syscolumns.name
FROM sysobjects
JOIN syscolumns ON sysobjects.id = syscolumns.id
JOIN systypes ON syscolumns.xtype=systypes.xtype
WHERE sysobjects.xtype='U'
ORDER BY sysobjects.name,syscolumns.colid

如果您希望表中的数据使用动态 sql,您可以在这些行上做一些事情:

Declare @Sql varChar(100)
Declare @Temp Table (Ind INT, TableName nvarchar(100))

Insert Into @Temp
Select Row_Number() Over(Order BY [Name]), [Name]
FROM
(
Select [Name]
from sys.tables
) AS D

Declare @index int
Set @index = 1
while @index < (Select Count(*) From @Temp)
begin
SET @SQL = ' Select * From ' + (Select TableName From @Temp Where Ind = @index)


exec (@SQL)
Set @index = @index + 1
End

关于sql server 2008 - 查找哪些表包含特定文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4197299/

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