Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 95071
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 10, 20262026-05-10T23:36:03+00:00 2026-05-10T23:36:03+00:00

I’m beginning my foray into fulltext search for MSSQL2005. This is a new, in-dev

  • 0

I’m beginning my foray into fulltext search for MSSQL2005. This is a new, in-dev database, so I can monkey around with it.

Let’s say I have a ‘Form’ table that has a one-to-many relationship to two other tables, ‘Answer’ and ‘Comment.’ I want the user to be able to enter one search term and have it peg all three of those tables via fulltext search. What’s the best way? It appears as though I can create an indexed view to speed things along.

If I do use an indexed view (is this the best route anyway?), how do I handle the one-to-many relationships? Let’s assume all I really want to figure out is the ID of the ‘Form’ table that would contain any search results found in the child Answer/Comment tables, so I can show the entire form that contains the located entries. An inner join on the view would result in multiple ‘master’ form rows being returned – doesn’t sound great for performance. How about concatenating all child answer/comment rows into one ‘column’ for the view? So instead of….

Form 1, Answer A, Comment A  Form 1, Answer B, Comment A  Form 1, Answer A, Comment B  Form 1, Answer B, Comment B 

…it’d be…

Form 1, Answer A Answer B, Comment A Comment B 

Remember all I care about is the ID of that master ‘form’ row.

This seems logical to me, but I’m not sure the best practices around fulltext search yet, so just curious if I’m approaching it correctly.

UPDATE: Looks like indexed views are pretty strict; no left joins, no subqueries, so I might go down the path of a summary table populated by triggers if it isn’t going to be too unwieldy.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-10T23:36:03+00:00Added an answer on May 10, 2026 at 11:36 pm

    In SQL you should use this rule of thumb: – start with the element you want to retrieve – add filters to limit the set of elements to retrieve

    that sounds like a no-brainer, but it’s really all you have to do. Here, you want Form elements (rows), so you write:

    SELECT ID FROM Form 

    and then you add the filters to limit the total set to the set of forms you’re interested in. You do this by using IN predicates. As you say Answer and Comment have a 1:n relationship with Form, this means that Answer and Comment have an FK to Form.ID. So we can add the where:

    WHERE ID IN (SELECT FormID FROM Answer WHERE CONTAINS(FullTextColumnInAnswer, @stringToSearch)) OR ID IN (SELECT FormID FROM Comment WHERE CONTAINS(FullTextColumnInComment, @stringToSearch)) 

    this will lead to a set of Form.ID values which are distinct and which are the IDs of forms which have at least 1 answer OR comment which contains the string to search in the field which is full-text-search enabled.

    On SqlServer 2000 this can be slower than on 2005, as you use multiple CONTAINS statements.

    You can also use CONTAINSTABLE() in join scenario’s instead, see the BOL for examples, though I’d go for the IN clause setup first to get things working.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 76k
  • Answers 77k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • added an answer Either execute your postback as an AJAX request, or add… May 11, 2026 at 3:15 pm
  • added an answer URLs use forward slashes (/), not backward ones (as windows).… May 11, 2026 at 3:15 pm
  • added an answer Disable the trigger before doing command-line updates and re-enable it… May 11, 2026 at 3:15 pm

Related Questions

I ran into a problem. Wrote the following code snippet: teksti = teksti.Trim() teksti
I am currently running into a problem where an element is coming back from
Seemingly simple, but I cannot find anything relevant on the web. What is the
Configuring TinyMCE to allow for tags, based on a customer requirement. My config is
Is it possible to replace javascript w/ HTML if JavaScript is not enabled on

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.