给定一个数字,我如何发现在什么表和列中可以找到它?
我不在乎速度快不快,只要管用就行。
给定一个数字,我如何发现在什么表和列中可以找到它?
我不在乎速度快不快,只要管用就行。
当前回答
到目前为止,我发现的最好和最通用的解决方案是通过管道将db的转储传递给您正在搜索的grep。
例如,Mysql:
mysqldump -pPASSWORD database | grep 'search phrase'
或者如果你得到了太多的结果,你可以把它们输出到一个文件:
mysqldump -pPASSWORD database | grep 'search phrase' > results.txt
其他回答
非常感谢这个有用的脚本。
如果你的表有不可转换的字段,你可能需要在代码中添加以下修改:
SET @ColumnName =
(
SELECT MIN(QUOTENAME(COLUMN_NAME))
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_SCHEMA = PARSENAME(@TableName, 2)
AND TABLE_NAME = PARSENAME(@TableName, 1)
AND DATA_TYPE NOT IN ('text', 'image', 'ntext')
AND QUOTENAME(COLUMN_NAME) > @ColumnName
)
克里斯
如果你安装了phpMyAdmin,使用它的搜索功能。
选择您的数据库。
请确保您选择的是DataBase,而不是表,否则您将得到一个完全不同的搜索对话框。
单击“搜索”页签 列表项选择所需的搜索词 选择要搜索的表
假设您想要获取数据库中所有具有名称的表,列名包含logintime,下面的MyDatabase是代码示例
use MyDatabase
SELECT t.name AS table_name,
SCHEMA_NAME(schema_id) AS schema_name,
c.name AS column_name
FROM sys.tables AS t
INNER JOIN sys.columns c ON t.OBJECT_ID = c.OBJECT_ID
WHERE c.name LIKE '%logintime%'
ORDER BY schema_name, table_name;
我正在寻找一个数值= 6.84 -使用这里的其他答案,我能够将我的搜索限制在这个范围内
Declare @sourceTable Table(id INT NOT NULL IDENTITY PRIMARY KEY, table_name varchar(1000), column_name varchar(1000))
Declare @resultsTable Table(id INT NOT NULL IDENTITY PRIMARY KEY, table_name varchar(1000))
Insert into @sourceTable(table_name, column_name)
select schema_name(t.schema_id) + '.' + t.name as[table], c.name as column_name
from sys.columns c
join sys.tables t
on t.object_id = c.object_id
where type_name(user_type_id) in ('decimal', 'numeric', 'smallmoney', 'money', 'float', 'real')
order by[table], c.column_id;
DECLARE db_cursor CURSOR FOR
Select table_name, column_name from @sourceTable
DECLARE @mytablename VARCHAR(1000);
DECLARE @mycolumnname VARCHAR(1000);
OPEN db_cursor;
FETCH NEXT FROM db_cursor INTO @mytablename, @mycolumnname
WHILE @ @FETCH_STATUS = 0
BEGIN
Insert into @ResultsTable(table_name)
EXEC('SELECT ''' + @mytablename + '.' + @mycolumnname + ''' FROM ' + @mytablename + ' (NOLOCK) ' +
' WHERE ' + @mycolumnname + '=6.84')
FETCH NEXT FROM db_cursor INTO @mytablename, @mycolumnname
END;
CLOSE db_cursor;
DEALLOCATE db_cursor;
Select Distinct(table_name) from @ResultsTable
出于开发目的,您可以将所需的表数据导出到单个HTML中,并对其进行直接搜索。