SqlServer如何创建全文索引

✅ 一、SQL Server 全文索引创建步骤(完整可执行)

1.1 前置检查(必须通过)

全文索引不是默认功能,很多开发环境根本没装。 请先在 SSMS 执行以下命令验证:

sql 复制代码
-- 检查1:全文搜索组件是否已安装
SELECT SERVERPROPERTY('IsFullTextInstalled') AS IsFullTextInstalled;
  • 返回值 = 1:继续下一步

  • 返回值 = 0必须找DBA安装全文组件(SQL Server安装介质修复,添加"全文和语义提取搜索"功能)

1.2 为当前数据库启用全文索引

sql 复制代码
EXEC sp_fulltext_database 'enable';

注意:该命令并非所有SQL Server版本必须,但执行无害。若报错"已启用",忽略即可

1.3 创建全文目录(容器)

sql 复制代码
CREATE FULLTEXT CATALOG FT_Catalog_LogRequest 
WITH ACCENT_SENSITIVITY = OFF;
  • ACCENT_SENSITIVITY = OFF:匹配时忽略重音(对中文无影响,推荐)

  • 如果只需要一个默认目录 ,可执行 CREATE FULLTEXT CATALOG FT_Catalog_LogRequest AS DEFAULT;

1.4 在目标表上创建全文索引------这是你的核心需求

sql 复制代码
CREATE FULLTEXT INDEX ON dbo.LogRequests
(
    ParamJson          -- 你要高速检索的大字段
        LANGUAGE 2052, -- 2052 = 简体中文。必须指定!否则中文分词失效
    ApiMethod,         -- (可选)其他需要全文检索的字段
    SysCode            -- (可选)
)
KEY INDEX PK_LogRequests   -- 表的主键名,必须单列、唯一、非空
ON FT_Catalog_LogRequest   -- 全文目录名,使用上一步创建的
WITH 
(
    CHANGE_TRACKING AUTO,      -- 自动跟踪数据变更(推荐)
    -- 或:CHANGE_TRACKING MANUAL, 手动更新;STOPLIST = SYSTEM   -- 使用系统停用词表
);

关于 LANGUAGE 2052 的严重性

如果不指定 LANGUAGE 2052,SQL Server 会使用默认语言(通常是英语)。英文分词器按空格分词,会把"托盘条码"整个当成一个词,根本无法匹配你输入的关键词,导致全文索引建了也白建

1.5 首次填充索引(立即生效)

sql 复制代码
ALTER FULLTEXT INDEX ON dbo.LogRequests START FULL POPULATION;
  • 数据量大时此操作消耗I/O,建议在业务低峰期执行。

  • 执行期间,已有数据的检索功能不可用,但表本身的增删改查不受影响。

✅ 二、创建完成后的验证与查询

2.1 验证索引是否创建成功

sql 复制代码
-- 查看该表上的全文索引
SELECT * FROM sys.fulltext_indexes 
WHERE object_id = OBJECT_ID('dbo.LogRequests');

-- 查看全文目录下的所有索引
SELECT * FROM sys.fulltext_catalogs;

2.2 正确使用全文检索(严禁再用LIKE

错误用法(全表扫描)

sql 复制代码
SELECT * FROM LogRequests WHERE ParamJson LIKE '%托盘条码123%';

正确用法(秒级响应)

sql 复制代码
-- 精确匹配关键词
SELECT Id, ApiMethod, RequestTime 
FROM LogRequests 
WHERE CONTAINS(ParamJson, '托盘条码123');

-- 多个关键词(AND关系)
SELECT Id, ApiMethod, RequestTime 
FROM LogRequests 
WHERE CONTAINS(ParamJson, '托盘 AND 条码');

-- 短语匹配(完全包含)
SELECT Id, ApiMethod, RequestTime 
FROM LogRequests 
WHERE CONTAINS(ParamJson, '"托盘条码123"');

-- 同时检索多个字段
SELECT Id, ApiMethod, RequestTime 
FROM LogRequests 
WHERE CONTAINS((ParamJson, ApiMethod), '托盘');
相关推荐
zjy2777713 分钟前
mysql如何选择合适的索引类型_mysql索引设计实战
jvm·数据库·python
笨蛋不要掉眼泪25 分钟前
Mysql架构揭秘:update语句的执行流程
数据库·mysql·架构
万邦科技Lafite32 分钟前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
秋91 小时前
ruoyi项目更换为mysql9.7.0数据库
数据库
Andya_net1 小时前
MySQL | MySQL 8.0 权限管理实践-精确赋予库、表只读等权限
android·数据库·mysql
筑梦之路3 小时前
harbor数据库报错权限异常如何处理——筑梦之路
数据库·harbor
czlczl200209253 小时前
理解 MySQL 行锁:两阶段锁协议与热点更新优化
数据库·mysql
AllData公司负责人3 小时前
通过Postgresql同步到Doris,全视角演示AllData数据中台核心功能效果,涵盖:数据入湖仓,数据同步,数据处理,数据服务,BI可视化驾驶舱
java·大数据·数据库·数据仓库·人工智能·python·postgresql
哆啦A梦15884 小时前
20, Springboot3+vue3实现前台轮播图和详情页的设计
javascript·数据库·spring boot·mybatis·vue3
渣渣盟4 小时前
Mysql入门到精通全集(SQL99)包含关系运算,软考数据库工程师复习首选
数据库·mysql·oracle