18

在构建存储过程/查询时,我可以/应该使用 LIKE 标准作为 INNER JOIN 的一部分吗?我不确定我问的是否正确,所以让我解释一下。

我正在创建一个过程,该过程将获取要在包含文本的列中搜索的关键字列表。如果我坐在控制台前,我会这样执行它:

SELECT Id, Name, Description
  FROM dbo.Card
 WHERE Description LIKE '%warrior%' 
       OR
       Description LIKE '%fiend%' 
       OR 
       Description LIKE '%damage%'

但是我在存储过程中进行“强类型”列表解析时学到的一个技巧是将列表解析为表变量/临时表,将其转换为正确的类型,然后对该表执行 INNER JOIN在我的最终结果集中。这在向过程发送整数 ID 列表时非常有用。我最终得到一个如下所示的最终查询:

SELECT Id, Name, Description
  FROM dbo.Card
       INNER JOIN @tblExclusiveCard ON dbo.Card.Id = @tblExclusiveCard.CardId

我想将此技巧与字符串列表一起使用。但由于我正在寻找一个特定的关键字,我将使用 LIKE 子句。所以理想情况下,我想我的最终查询应该是这样的:

SELECT Id, Name, Description
  FROM dbo.Card
       INNER JOIN @tblKeyword ON dbo.Card.Description LIKE '%' + @tblKeyword.Value + '%'

这可能/推荐吗?

有没有更好的方法来做这样的事情?


我将通配符放在子句两端的原因是因为卡片文本中使用了“archfiend”、“beast-warrior”、“direct-damage”和“battle-damage”术语。

我的印象是,根据性能,我可以使用我指定的查询还是使用全文关键字搜索来完成相同的任务?

除了让服务器对我想要进行文本搜索的字段进行文本索引之外,我还需要做些什么吗?

4

10 回答 10

10

试试这个

    select * from Table_1 a
    left join Table_2 b on b.type LIKE '%' + a.type + '%'

这种做法并不理想。谨慎使用。

于 2013-01-29T19:35:43.420 回答
5

您的第一个查询将起作用,但需要进行全表扫描,因为该列上的任何索引都将被忽略。您还必须执行一些动态 SQL 来生成所有 LIKE 子句。

如果您使用 SQL Server,请尝试全文搜索或查看其中一个Lucene实现。乔尔最近谈到了他的成功。

于 2008-08-21T17:06:11.050 回答
2

尝试一下...

select * from table11 a inner join  table2 b on b.id like (select '%'+a.id+'%') where a.city='abc'.

它对我有用。:-)

于 2015-05-27T13:22:46.740 回答
1

您似乎正在寻找全文搜索。因为您想根据卡片描述查询一组关键字并找到任何匹配项?正确的?

于 2008-08-21T16:57:17.170 回答
1

就个人而言,我以前做过,而且对我来说效果很好。我能看到的唯一问题可能是未索引列的问题,但我认为您会遇到与 where 子句相同的问题。

我给你的建议是看看两者之间的执行计划。我敢肯定,这会根据情况而有所不同,就像所有好的编程问题一样。

于 2008-08-21T16:57:28.357 回答
1

@Dillie-O
这张桌子有多大?
描述字段的数据类型是什么?

如果其中任何一个都很小,那么全文搜索将是多余的。

@Dillie-O
也许不是您要寻找的答案,但我会提倡架构更改...

建议的架构:

create table name(
    nameID identity / int
   ,name varchar(50))

create table description(
    descID identity / int
   ,desc varchar(50)) --something reasonable and to make the most of it alwase lower case your values

create table nameDescJunc(
    nameID  int
    ,descID int)

这将让您使用索引而不必实施解决方案,并保持您的数据原子。

相关:标签或标记的推荐 SQL 数据库设计

于 2008-08-21T17:27:33.060 回答
1

我在存储过程中进行“强类型”列表解析的一个技巧是将列表解析为表变量/临时表

我认为您可能在这里暗示的是将要包含的关键字放入表中,然后使用关系除法来查找匹配项(也可以使用另一个表来排除要排除的单词)。有关 SQL 中的工作示例,请参阅Joe Celko 的关键字搜索

于 2009-05-01T08:52:31.220 回答
0

性能将取决于您使用的实际服务器、数据架构和数据量。对于当前版本的 MS SQL Server,该查询应该可以正常运行(MS SQL Server 7.0 存在该语法问题,但已在 SP2 中解决)。

您是否通过分析器运行该代码?如果性能足够快并且数据具有适当的索引,那么您应该已准备就绪。

于 2008-08-21T17:01:59.920 回答
0

LIKE '%fiend%' 永远不会使用搜索,LIKE 'fiend%' 会。简单的通配符搜索是不可搜索的

于 2008-08-21T17:08:00.313 回答
0

试试这个;

SELECT Id, Name, Description
FROM dbo.Card
INNER JOIN @tblKeyword ON dbo.Card.Description LIKE '%' + 
                                CONCAT(CONCAT('%',@tblKeyword.Value),'%') + '%'
于 2009-05-21T07:40:35.017 回答