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

  • SEARCH
  • Home
  • 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
  • 2 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

Related Questions

link Im having trouble converting the html entites into html characters, (&# 8217;) i
I have a string like this: La Torre Eiffel paragonata all’Everest What PHP function
this is what i have right now Drawing an RSS feed into the php,
I'm parsing an RSS feed that has an ’ in it. SimpleXML turns this
This could be a duplicate question, but I have no idea what search terms
Does anyone know how can I replace this 2 symbol below from the string
For some reason, after submitting a string like this Jack’s Spindle from a text
I have a jquery bug and I've been looking for hours now, I can't
I have this code to decode numeric html entities to the UTF8 equivalent character.
I have a French site that I want to parse, but am running into

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.