Solved

Help in SQL Full Text Search

Posted on 2016-10-27
3
36 Views
Last Modified: 2016-10-27
Hi guys,

I need to search the address table and have implemented full text search in it. However there is one thing happening. When the building number is a single digit the search doesn't return anything

Doesn't return reslut
DECLARE  @GlobalStringFraction NVARCHAR(100)
SET @GlobalStringFraction ='9 l10 0aj'

 SET @GlobalStringFraction = REPLACE(@GlobalStringFraction, N',',
                                                N'');
PRINT @GlobalStringFraction
            SET @GlobalStringFraction = REPLACE(@GlobalStringFraction, N'WAY',
                                                N'');

PRINT @GlobalStringFraction
            SET @GlobalStringFraction = REPLACE(REPLACE(REPLACE(@GlobalStringFraction,
                                                              N' ', N'<>'),
                                                        N'><', N''), N'<>',
                                                N' ');
PRINT @GlobalStringFraction
            SET @GlobalStringFraction = N'"' + REPLACE(@GlobalStringFraction,
                                                       N' ', N'" AND "')
                + N'"';
PRINT @GlobalStringFraction
DECLARE @str varchar(5000) 
Set @str= (SELECT TOP(1000) Count(*)
            FROM    AddressSearchString AS t
                    INNER JOIN CONTAINSTABLE([dbo].AddressSearchString, *, @GlobalStringFraction)
                    AS k ON t.Id = k.[KEY]); 
					
	PRINT @str 
	PRINT @GlobalStringFraction

Open in new window



But when i replace 9 with with 10 or higher the search returns the result

Returns the Result
DECLARE  @GlobalStringFraction NVARCHAR(100)
SET @GlobalStringFraction ='10 l10 0aj'

 SET @GlobalStringFraction = REPLACE(@GlobalStringFraction, N',',
                                                N'');
PRINT @GlobalStringFraction
            SET @GlobalStringFraction = REPLACE(@GlobalStringFraction, N'WAY',
                                                N'');

PRINT @GlobalStringFraction
            SET @GlobalStringFraction = REPLACE(REPLACE(REPLACE(@GlobalStringFraction,
                                                              N' ', N'<>'),
                                                        N'><', N''), N'<>',
                                                N' ');
PRINT @GlobalStringFraction
            SET @GlobalStringFraction = N'"' + REPLACE(@GlobalStringFraction,
                                                       N' ', N'" AND "')
                + N'"';
PRINT @GlobalStringFraction
DECLARE @str varchar(5000) 
Set @str= (SELECT TOP(1000) Count(*)
            FROM    AddressSearchString AS t
                    INNER JOIN CONTAINSTABLE([dbo].AddressSearchString, *, @GlobalStringFraction)
                    AS k ON t.Id = k.[KEY]); 
					
	PRINT @str 
	PRINT @GlobalStringFraction

Open in new window


It seems that it is taking 0-9 as noise words. But if i disable stoplist my search goes considerably slow on front end

I have attached some sample data herewith

regards
Ali
Data.xlsx
0
Comment
Question by:shah36
  • 2
3 Comments
 
LVL 69

Accepted Solution

by:
ScottPletcher earned 500 total points
ID: 41862568
You can adjust the noise word to remove 0 thru 9 but not to include everything else.  That is, you can create a custom noise list.
0
 

Author Comment

by:shah36
ID: 41862574
Thanks! is a custom noise list inherited by system noise list? I mean if i just eliminate some words from custom stop list will other noise words still be there?
0
 

Author Closing Comment

by:shah36
ID: 41862604
Thank you very much for giving me this idea. I have used custom stop list and created it from system stop list. have removed 0-9 words and it doesn't slow down as well.

thanks again
0

Featured Post

Backup Your Microsoft Windows Server®

Backup all your Microsoft Windows Server – on-premises, in remote locations, in private and hybrid clouds. Your entire Windows Server will be backed up in one easy step with patented, block-level disk imaging. We achieve RTOs (recovery time objectives) as low as 15 seconds.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Why is this different from all of the other step by step guides?  Because I make a living as a DBA and not as a writer and I lived through this experience. Defining the name: When I talk to people they say different names on this subject stuff l…
I have a large data set and a SSIS package. How can I load this file in multi threading?
This video shows, step by step, how to configure Oracle Heterogeneous Services via the Generic Gateway Agent in order to make a connection from an Oracle session and access a remote SQL Server database table.
Via a live example, show how to set up a backup for SQL Server using a Maintenance Plan and how to schedule the job into SQL Server Agent.

867 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

22 Experts available now in Live!

Get 1:1 Help Now