116 lines
5.1 KiB
Transact-SQL

EXEC sp_fulltext_database 'enable'
go
IF EXISTS (select ssche.name as TABLE_OWNER, sobj.name as TABLE_NAME, sidx.name as FULLTEXT_KEY_INDEX_NAME,
sidxcol.column_id as FULLTEXT_KEY_COLID, sftidx.is_enabled as FULLTEXT_INDEX_ACTIVE, scat.name as FULLTEXT_CATALOG_NAME
from sys.objects as sobj
join sys.fulltext_indexes as sftidx on (sobj.object_id = sftidx.object_id)
join sys.indexes as sidx on(sftidx.unique_index_id = sidx.index_id and sftidx.object_id = sidx.object_id)
join sys.schemas as ssche on (sobj.schema_id = ssche.schema_id)
join sys.index_columns as sidxcol on (sftidx.object_id = sidxcol.object_id and sftidx.unique_index_id = sidxcol.index_id)
left outer join sys.fulltext_catalogs as scat on (scat.fulltext_catalog_id = sftidx.fulltext_catalog_id)
where sobj.name ='CONTENTS')
DROP FULLTEXT INDEX ON CONTENTS
IF EXISTS (select ssche.name as TABLE_OWNER, sobj.name as TABLE_NAME, sidx.name as FULLTEXT_KEY_INDEX_NAME,
sidxcol.column_id as FULLTEXT_KEY_COLID, sftidx.is_enabled as FULLTEXT_INDEX_ACTIVE, scat.name as FULLTEXT_CATALOG_NAME
from sys.objects as sobj
join sys.fulltext_indexes as sftidx on (sobj.object_id = sftidx.object_id)
join sys.indexes as sidx on(sftidx.unique_index_id = sidx.index_id and sftidx.object_id = sidx.object_id)
join sys.schemas as ssche on (sobj.schema_id = ssche.schema_id)
join sys.index_columns as sidxcol on (sftidx.object_id = sidxcol.object_id and sftidx.unique_index_id = sidxcol.index_id)
left outer join sys.fulltext_catalogs as scat on (scat.fulltext_catalog_id = sftidx.fulltext_catalog_id)
where sobj.name ='DOCUMENTS')
DROP FULLTEXT INDEX ON Documents
GO
GO
declare @ftc as sysname
IF EXISTS(select name from sys.fulltext_catalogs)
begin
select @ftc = 'DROP FULLTEXT CATALOG ' + name from sys.fulltext_catalogs
exec sp_sqlexec @ftc
end
CREATE FULLTEXT CATALOG FT_Catalog
go
CREATE FULLTEXT INDEX ON Contents
(
Text
Language 1033
)
KEY INDEX PK_Contents ON FT_Catalog
WITH CHANGE_TRACKING AUTO
GO
CREATE FULLTEXT INDEX ON Documents
(
DocAscii
Language 1033
)
KEY INDEX PK_Documents ON FT_Catalog
WITH CHANGE_TRACKING AUTO
GO
select case FullTextCatalogProperty('FT_Catalog', 'PopulateStatus')
when 0 then 'Idle'
when 1 then 'Full population in progress'
when 2 then 'Paused'
when 3 then 'Throttled'
when 4 then 'Recovering'
when 5 then 'Shutdown'
when 6 then 'Incremental population in progress'
when 7 then 'Building index'
when 8 then 'Disk is full. Paused.'
when 9 then 'Change tracking'
else 'Error reading FullTextCatalogProperty PopulateStatus'
end
select FullTextCatalogProperty('FT_Catalog', 'PopulateStatus')
/*
SELECT * FROM contents WHERE CONTAINS(text, '"FOLLOW*"') -- prefix Follow
SELECT * FROM contents WHERE CONTAINS(text, '"FOLLOW"') -- exact Follow
SELECT * FROM contents WHERE CONTAINS(text, 'PORV AND SG') -- boolean
SELECT * FROM contents WHERE CONTAINS(text, 'PORV NEAR SG') -- boolean
SELECT * FROM contents WHERE CONTAINS(text, '"SG AND PORV"') -- boolean
SELECT * FROM contents WHERE CONTAINS(text, '"SG*" AND "PORV*"') -- boolean
SELECT * FROM contents WHERE CONTAINS(text, '"SG" AND "PORV"') -- boolean
SELECT * FROM contents WHERE CONTAINS(text, '"SG*" AND "PORV*"') -- boolean
AND NOT CONTAINS(text, '"SG" AND "PORV"') -- boolean
SELECT * FROM contents WHERE CONTAINS(text, '"SG PORV"') -- boolean
SELECT * FROM contents WHERE text like '%SG PORV%' -- SQL Search
SELECT * FROM contents WHERE CONTAINS(text, 'FORMSOF(INFLECTIONAL, "foot")'); -- inflectional foot
SELECT * FROM contents WHERE CONTAINS(text, '"run*"'); -- prefix run
SELECT * FROM contents WHERE CONTAINS(text, 'FORMSOF(INFLECTIONAL, "run")'); -- inflectional run
SELECT * FROM contents WHERE CONTAINS(text, '"run*"')
AND NOT CONTAINS(text, 'FORMSOF(INFLECTIONAL, "run")'); -- prefix run and not inflectional run
SELECT * FROM contents WHERE CONTAINS(text, '"vacuum decrease*"'); -- prefix vacuum decrease
SELECT count(*) DG_or_DieselGenerator FROM contents where text like '%DG%' OR text like '%DIESEL GENERATOR%'
SELECT count(*) DG FROM contents where text like '%DG%'
SELECT count(*) DieselGenerator FROM contents where text like '%DIESEL GENERATOR%'
SELECT * FROM contents where text like '%DIESEL GENERATOR%'
SELECT * FROM contents WHERE CONTAINS(text, 'FORMSOF(THESAURUS, "DG*")'); --
SELECT * FROM contents WHERE CONTAINS(text, 'FORMSOF(THESAURUS, "DIESEL GENERATOR")'); --
SELECT * FROM contents WHERE FREETEXT(text, '"DIESEL GENERATOR*"'); --
SELECT * FROM contents WHERE FREETEXT(text, '"DG*"'); --
SELECT * FROM contents WHERE CONTAINS(text, 'FORMSOF(THESAURUS, "SG")'); --
SELECT * FROM contents WHERE CONTAINS(text, 'FORMSOF(THESAURUS, "STEAM GENERATOR")'); --
EXEC sp_fulltext_load_thesaurus_file 1033;
SELECT * FROM contents WHERE CONTAINS(text, '"RUN*" and "PUMP*"'); --
SELECT * FROM contents WHERE CONTAINS(text, 'FORMSOF(INFLECTIONAL, "run") and "PUMP*"'); --
SELECT * FROM contents WHERE CONTAINS(text, '"RUN*" and "PUMP*"') --
AND NOT CONTAINS(text, 'FORMSOF(INFLECTIONAL, "run") and "PUMP*"'); --
*/