1

我想知道如何安装一个尽可能便携的 SQL 来查询表的所有列以查找特定短语,例如:

桌子

ID | Name           | text      | Date       | Author  | Status
1  | Augusto Weiand | Test text | 2010-01-01 | Deividi | 1

询问

SELECT * 
FROM table 
WHERE columns LIKE '%augusto%2010%text%"

我没有提供足够的细节,对不起,我喜欢做一个动态 SQL,我不需要用 'AND' 或 'OR' 指定列,因为在 Postgres 中可以这样做:

Select * 
From table 
Where table::text ~~ '%augusto%2010%text%'
4

4 回答 4

2

这是可行的,尽管我强烈建议您研究全文搜索以提高效率;

为避免一一查找所有字段中的所有模式,您可以在其中进行连接和搜索;

SELECT *
FROM (SELECT id,CONCAT(name,'|',text,'|',date,'|',author,'|',status) txt
      FROM Table1) a
WHERE txt LIKE '%augusto%'
  AND txt LIKE '%2010%'
  AND txt LIKE '%text%';

请注意,这里没有索引会对您有所帮助,因为您在计算列中进行搜索。另一方面,由于您使用前导通配符进行搜索,%searchterm因此即使逐字段搜索,您也不会从索引中获得太多帮助:)

一个用于测试的 SQLfiddle

于 2013-07-27T13:10:02.730 回答
2

以下是连接动态 SQL 中的值的方法:

set @Pattern = '%augusto%';

select @q := concat('select * from Table1 ',
                   'where concat(', group_concat(column_name), ', "") like "', @Pattern, '"'
                   )
from information_schema.columns c
where table_name = 'Table1';

prepare st from @q;
execute st;

deallocate prepare st;

当然,动态 SQL 并不是特别便携。这个想法适用于大多数数据库。代码看起来会有所不同。

在这里测试和工作。

最后,您可以使用变量替换来做到这一点(这是更好的方法):

select @q := concat('select * from Table1 ',
                   'where concat(', group_concat(column_name), ', "") like ?'
                   )
from information_schema.columns c
where table_name = 'Table1';

set @p = '%augusto%';

prepare st from @q;
execute st using @p;

deallocate prepare st;

还测试了 (;-)。

于 2013-07-27T13:22:53.347 回答
1

尝试这个

   Select * FROM table WHERE text LIKE "%text%"
                          OR date LIKE "%2010%"
                          OR Name LIKE "%augusto%"

如果你想把它们都放在一起,那么使用 AND

   Select * FROM table WHERE text LIKE "%text%"
                          AND date LIKE "%2010%"
                          AND Name LIKE "%augusto%"
于 2013-07-27T13:03:23.337 回答
1

您可以使用此存储过程在表的所有列中搜索文本

CREATE PROCEDURE dbo.sp_FindStringInTable @stringToFind VARCHAR(100), 
@schema 
sysname, @table sysname 
AS

BEGIN TRY
DECLARE @sqlCommand varchar(max) = 'SELECT * FROM [' + @schema + '].[' + 
@table + '] WHERE ' 

SELECT @sqlCommand = @sqlCommand + '[' + COLUMN_NAME + '] LIKE ''' + 
@stringToFind + ''' OR '
FROM INFORMATION_SCHEMA.COLUMNS 
WHERE TABLE_SCHEMA = @schema
AND TABLE_NAME = @table 
AND DATA_TYPE IN ('char','nchar','ntext','nvarchar','text','varchar')

SET @sqlCommand = left(@sqlCommand,len(@sqlCommand)-3)
EXEC (@sqlCommand)
PRINT @sqlCommand
END TRY

BEGIN CATCH 
PRINT 'There was an error. Check to make sure object exists.'
PRINT error_message()
END CATCH 

像这样执行

EXEC sp_FindStringInTable '%searchword%','schema_name', 'tablename'
于 2018-02-26T06:48:00.063 回答