SQLSERVER全文目录全文索引的使用方法和区别讲解
这篇文章主要介绍了SQLSERVER全文目录全文索引的使用方法,有图有代码,大家参考使用吧 先介绍一下SQLSERVER中的存储类对象,哈哈,先介绍一下概念嘛,让新手老手都有一个认知
数据库【存储】|【全文目录】节点是用于保存和管理【全文索引】的节点。全文目录通常是由同一数据库中的零个或多个数据表的全文索引构成的。 在SQLSERVER2005中使用全文索引的主要步骤如下: (1)首先需要创建全文目录。 创建全文目录的方法非常简单。通过SSMS以及T-SQL都可以实现创建全文目录的功能。 最后说一下全文索引的优缺点和注意事项: (1)全文索引可对char、varchar、nchar、nvarchar、text、ntext、image、xml、varbinary 或 varbinary(max) 类型字段进行检索,是解决海量数据模糊查询的好办法。 与全文搜索不同,LIKE Transact-SQL 谓词仅对字符模式( char、varchar、nchar、nvarchar)有效。另外,不能使用 LIKE 谓词来查询格式化的二进制数据。此外,对大量非结构化的文本数据执行 LIKE 查询要比对相同数据执行同样的全文查询慢得多。对数百万行文本数据进行的 LIKE 查询可能需要几分钟的时间才能返回结果;而对于同样的数据,全文查询只需要几秒甚至更少的时间,具体取决于返回的行数及其大小。另一个考虑因素是 LIKE 仅对整个表执行简单模式扫描。相反,全文查询可识别语言,它在索引和查询时应用特定的转换,例如,筛选非索引字并进行同义词库和变形扩展。这些转换可帮助全文查询改进其撤回以及结果的最终排名 最最后,讲一下全文索引的用法: (1)CONTAINS语句的功能是在表的所有列或指定列中搜索:一个字或短语;一个字或短语的前缀;与一个字相近的另一个字;一个字的派生字;一个重复出现的字。 T-SQL语句 复制代码 代码如下:
pratice是我的一个测试数据库,d是test表的其中一个字段,以上T-SQL语句的意思是查找d字段里包含字符串"基数行"的记录 全文搜索开启方法 一、创建全文索引 1、使用SSMS 2、使用T-SQL Create FullText Index On Production.ProductDescription (Description) Key Index 二、填充全文索引 1、使用SSMS 2、使用T-SQL Alter FullText Index On Production.ProductDescription Start Full Population; 三、查询 1、FreeText函数 Select ProductDescriptionID,Description From Production.ProductDescription 2、FreeTextTable函数 select * from ?FreeTextTable(Production.ProductDescription,Description,N'bike') 上述查询仅返两个列:Key、Rank 。 通常使用下述查询: Select PD.ProductDescriptionID,PD.Description,KeyTable.[Key],KeyTable.Rank 3、Contains函数 -- 查询完全匹配“bike”的行和包含“bike”前缀的所有词的行: -- 关键词Formsof、Inflectional、Thesaurus允许搜索项的变形匹配 -- Inflectional会使搜索处理搜索中的词干,例如,“drive”与“drove”、“driven”、“driving”匹配 -- Thesaurus会匹配同义词,例如,“metal”会匹配“gold”、“aluminum”、“steel”等 注意:所有的词表文件安装时都为空。要使用词表匹配,必须填充这些文件。所有词表文件都是XML文件,位于默认的SQL Server安装路径下的FTDATA文件夹。 -- near可以搜索多个关键词(邻近词) -- 还可以给特殊的搜索选项指派相对权重 4、ContainsTable函数 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |