首页 >数据库 >mysql教程 >如何在 SQL Server 中高效搜索逗号分隔字符串中的值?

如何在 SQL Server 中高效搜索逗号分隔字符串中的值?

Linda Hamilton
Linda Hamilton原创
2025-01-09 17:32:42728浏览

How Can I Efficiently Search for Values Within Comma-Delimited Strings in SQL Server?

在逗号分隔的 SQL Server 列中查找特定值

使用 SQL Server 2008,您可能需要查找包含逗号分隔值的列中特定值所在的行。 挑战在于将该值定位在字符串中的任何位置,而不仅仅是精确的字符串匹配。

让我们来看看这个问题:

  • 示例表:

    <code class="language-sql">  CREATE TABLE DelimitedValues (id INT, ColumnName VARCHAR(100));
      INSERT INTO DelimitedValues VALUES
      (1, 'Cat,Dog,Sparrow,Trout,Cow,Seahorse'),
      (2, 'Mouse');</code>
  • 目标: 识别 ColumnName 包含特定值(如“猫”或“羊”)的行。

IN这样的标准方法是不够的,因为它们不处理嵌入在逗号分隔列表中的值。需要更复杂的方法。

一个强大的解决方案使用字符串连接和 LIKE 运算符:

<code class="language-sql">SELECT id
FROM DelimitedValues
WHERE (',' + RTRIM(ColumnName) + ',') LIKE '%,' + @search + ',%'</code>

此技术可确保搜索值 (@search) 用逗号括起来,无论其在列表中的位置如何,都可以进行检测。 例如:

  • ColumnName 持有“猫、狗、麻雀、鳟鱼、牛、海马”
  • @search 是“猫”
  • 结果: 返回第 1 行,因为在逗号分隔的字符串中找到了“Cat”。

此方法可靠地处理所有情况:列表开头、中间或末尾的值以及单值条目。

以上是如何在 SQL Server 中高效搜索逗号分隔字符串中的值?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn