对 SQL Server 2008 记录进行排序时忽略停用词

发布于 2024-11-16 12:02:31 字数 368 浏览 6 评论 0原文

我有一个包含书名字段的表。我希望能够对记录进行这样的排序:

  1. 古代鳄鱼
  2. 安妮阿姨的鳄鱼 鳄鱼
  3. 完整指南
  4. 国家鳄鱼
  5. 不要碰鳄鱼!
  6. 轻松狩猎鳄鱼

等等,忽略“A”、“An”和“A”、“An”和“A”。当它们作为标题的第一个词出现时,使用“The”。 (它们也可以在标题中的任何位置被忽略。)

我知道这些是 SQL Server 2008 中的停用词,因此如果有人在搜索中使用它们,可以忽略它们。

但有没有办法让 ORDER BY 忽略它们呢? (如果有影响,查询将使用 ASP.NET 中的 LinqDataSource。)

谢谢!

I have a table that has a book title field. I would like to be able to sort the records like this:

  1. The Ancient Alligator
  2. Aunt Annie's Alligator
  3. A Complete Guide to Alligators
  4. Countrified Alligators
  5. Don't Touch the Alligator!
  6. An Effortless Alligator Hunt

and so on, ignoring "A", "An", & "The" when they appear as the first word of the title. (They could also be ignored anywhere in the title.)

I know these are stopwords in SQL Server 2008, so they can be ignored if someone uses them in a search.

But is there a way to make them ignored by ORDER BY? (If it makes a difference, the query will use a LinqDataSource in ASP.NET.)

Thanks!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

别念他 2024-11-23 12:02:32

如果您有大量记录,则使用replace() 计算排序键将无法扩展。

最好的方法是添加一个额外的表字段,其中包含删除了 A/An/The 等前缀的标题,并确保它有一个索引以加快排序速度。然后您可以只按这个新字段排序,但显示原始未更改的字段。

Computing a sort key by using replace() won't scale if you have a large number of records.

The best way is to add an additional table field containing the title with A/An/The etc prefixes removed and make sure it has an index to speed up sorting. Then you can just order by this new field but display the original unchanged field.

云巢 2024-11-23 12:02:32

也许是这样的。

;with T(Title) as
(
  select 'The Ancient Alligator'          union all
  select 'Aunt Annie''s Alligator'        union all
  select 'A Complete Guide to Alligators' union all
  select 'Countrified Alligators'         union all
  select 'Don''t Touch the Alligator!'    union all
  select 'An Effortless Alligator Hunt'
)

select Title
from T
order by replace(
         replace(
         replace(T.Title, 
         'A ', ''), 
         'An ', ''), 
         'The ', '')

结果:

Title
------------------------------
The Ancient Alligator
Aunt Annie's Alligator
A Complete Guide to Alligators
Countrified Alligators
Don't Touch the Alligator!
An Effortless Alligator Hunt

Something like this perhaps.

;with T(Title) as
(
  select 'The Ancient Alligator'          union all
  select 'Aunt Annie''s Alligator'        union all
  select 'A Complete Guide to Alligators' union all
  select 'Countrified Alligators'         union all
  select 'Don''t Touch the Alligator!'    union all
  select 'An Effortless Alligator Hunt'
)

select Title
from T
order by replace(
         replace(
         replace(T.Title, 
         'A ', ''), 
         'An ', ''), 
         'The ', '')

Result:

Title
------------------------------
The Ancient Alligator
Aunt Annie's Alligator
A Complete Guide to Alligators
Countrified Alligators
Don't Touch the Alligator!
An Effortless Alligator Hunt
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文