데이터 베이스 MySQL 튜토리얼 向SQL Server全文索引进军,艰难历程

向SQL Server全文索引进军,艰难历程

Jun 07, 2016 pm 05:45 PM
server 색인 행진하다

向SQL Server全文索引进军,艰难历程 写这篇文章本来不在计划之内,以前也没有接触过全文索引。偶然的一次备课中。突然有了灵感。决定将自己创建及其使用全文索引的过程记录下来,以备后续使用。 至于全文索引的概念,网上一大堆,这里就不再赘述。直接切入正

向SQL Server全文索引进军,艰难历程

 

      写这篇文章本来不在计划之内,以前也没有接触过全文索引。偶然的一次备课中。突然有了灵感。决定将自己创建及其使用全文索引的过程记录下来,以备后续使用。

至于全文索引的概念,网上一大堆,这里就不再赘述。直接切入正题。

创建全文索引步骤:

1:对着数据库点击右键-选择属性-选择文件,选中“使用全文索引”

 

该选项只要勾选就可以了,默认都是勾选的。

2:对着表点击右键-全文索引-定义全文索引

3:点击下一步,如果这个表中没有唯一性索引就会出现下图所示

 

4:选择表列,选择断字符语言。

5:点击下一步,这里的选项要注意,如果不想再表、视图更改的时候更新全文索引,那就选择不跟踪更改;这样就可以选择是否在创建索引时启动完全填充了。

6:点击下一步创建索引要保存的目录,香港服务器,全文索引的索引文件是以文件的形式保存到硬盘上的。

7:之后就可以设置自动填充、手动跟踪更改,还有设置计划了。

上述步骤虽然简单,但是我在创建时,碰到了N多问题

问题描述:

01.首先我对表点击右键的时候,全文索引菜单项是灰色,不可用状态

如下图

 

通过查询资料发现需要执行如下命令开启该菜单项目   

 EXEC sp_fulltext_database 'ensable'

这样全文索引就变成可用状态了。

如果想让全文索引重新变暗(当然一般人不会这么做),可以执行如下代码

 EXEC sp_fulltext_database 'disable'

02.在使用全文索引进行检索时,必须要开启全文检索服务

 

默认该服务是关闭的。

03.当我创建好全文索引后,通过如下语句进行索引关键字时

Select content from info infoinfo

where contains(content, '但为了获得最佳性能,建议使用主键约束或唯一约束。')

出现了如下提示:

"SQL Server 在与全文筛选器后台程序宿主(FDHost)进程通信时遇到错误 0x80070218。请确保 FDHost 进程正在运行。若要重新启动 FDHost 进程,请运行 sp_fulltext_service 'restart_all_fdhosts' 命令或重新启动 SQL Server 实例。 "

经过反复摸索, 发现需要在 SQL配置工具里面, 更改全文服务的运行账户, 有默认的 "系统内设"-->"本地账户", 搞定!

 

但是更改完该设置后,我依然没能笑出声来,原因是接下来虽然没有错误发生,但是却检索不出我需要的结果,但通过like进行检索,的确有数据。

select content from infoinfo

 where content like '%但为了获得最佳性能,建议使用主键约束或唯一约束。%'

这时候,我差点崩溃了。没办法,继续搜索资料。

最后,从微软官网上搜索到这样一篇文章

 

里面详细讲述了产生该问题的原因,以及对应的解决方案

请注意

重要提示: 本文包含有关修改注册表的信息。 在修改注册表之前,请务必对其进行备份,并确保您了解如何还原注册表发生问题。有关如何备份、 还原,和编辑注册表单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:

256986Microsoft Windows 注册表的说明

症状

具有 300 KB 以上的文本 (超过 150 KB ntext列的 UNICODE 文本) 的文本的全文启用的列上运行全文索引包含查询时,美国空间,您可能会收到一条消息,"0 行受影响",即使存在有效的结果。

原因

Microsoft 搜索服务 (MSSearch.exe) 维护 SQL Server 7.0 全文搜索来搜索的基于字符的数据类型,如字符、 varchar、文本和ntext的全文目录。文本可以有多个 300 KB 的数据根据您定义的列 (ntext可以有多个 150 KB 的 UNICODE 文本)。全文索引填充时,MSSearch 服务从文本列中检索所有非重复的单词,并将它们存储在虚拟内存中,它将它们合并到主索引之前。MSSearch 属性可防止 MSSearch 服务占用的虚拟内存。MSSearch 属性由下面的注册表和它的值控制:

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Search\1.0\Indexer\SQLServer\ \ MaxBytesPerFile

例如: Full_Text_Catalog_Name = SQL0000500005
此注册表项的默认值设置为 307200 (300 KB)。因此,MSSearch 服务假定 300 KB 的文本作为重要和填充全文索引时将忽略文本列的其余的数据。
因此,当您运行全文的 CONTAINS 子句查询来搜索后 300 KB 的文本将出现在文本栏中的单词,不可能获得有效的结果。

替代方法

警告: 如果注册表编辑器使用不当,可能会导致严重的问题,可能需要您重新安装操作系统。注册表编辑器使用不当所产生的问题,Microsoft 不能保证您可以解决。使用注册表编辑器需要您自担风险。
若要变通解决此问题:

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Search\1.0\Indexer\SQLServer\Full_Text_Catalog_Name\

(例如: Full_Text_Catalog_Name = SQL0000500005)。

但是真正按照这个文档进行操作时,再次碰到了问题,就是第3步到1.0后,没有Indexer文件夹,我晕,只能再次硬着头皮查资料。结果,网上资料很少,却搜到一篇一模一样的英文文章,是这样写的

PRB: A Full-Text Search Query on TEXT or NTEXT Column Does Not Return Valid Results

Article ID: 241113 - View products that this article applies to.

This article was previously published under Q241113

Notice
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Windows 11에서 파일과 폴더를 숨기고 검색에서 제거하는 방법은 무엇입니까? Windows 11에서 파일과 폴더를 숨기고 검색에서 제거하는 방법은 무엇입니까? Apr 26, 2023 pm 11:07 PM

<h2>Windows 11 검색에서 파일 및 폴더를 숨기는 방법</h2><p>가장 먼저 살펴봐야 할 것은 Windows 검색 파일의 위치를 ​​사용자 지정하는 것입니다. 이러한 특정 위치를 건너뛰면 보호하려는 파일을 숨기는 동시에 결과를 더 빨리 볼 수 있습니다. </p><p>Windows 11 검색에서 파일과 폴더를 제외하려면 다음 단계를 따르세요. </p><ol&

다음은 Windows 11 검색 표시줄을 사용할 수 없는 문제를 해결하는 6가지 방법입니다. 다음은 Windows 11 검색 표시줄을 사용할 수 없는 문제를 해결하는 6가지 방법입니다. May 08, 2023 pm 10:25 PM

Windows 11에서 검색 창이 작동하지 않는 경우 즉시 검색 창을 활성화하고 실행할 수 있는 몇 가지 빠른 방법이 있습니다! 모든 Microsoft 운영 체제에서는 때때로 결함이 발생할 수 있으며 최신 운영 체제도 이 규칙에서 면제되지 않습니다. 또한 Reddit의 u/zebra_head1 사용자가 지적한 대로 22H2Build22621.1413이 포함된 Windows 11에서도 동일한 오류가 나타납니다. 사용자들은 작업 표시줄 검색 상자를 무작위로 전환하는 옵션이 사라졌다고 불평했습니다. 그러므로 어떤 상황에도 대비해야 합니다. 내 컴퓨터의 검색창에 입력할 수 없는 이유는 무엇입니까? 컴퓨터에 입력할 수 없는 현상은 다양한 요인과 프로세스로 인해 발생할 수 있습니다. 주의해야 할 사항은 다음과 같습니다. Ctfmon.

Windows 서버 백업을 설치, 제거 및 재설정하는 방법 Windows 서버 백업을 설치, 제거 및 재설정하는 방법 Mar 06, 2024 am 10:37 AM

WindowsServerBackup은 WindowsServer 운영 체제와 함께 제공되는 기능으로, 사용자가 중요한 데이터 및 시스템 구성을 보호하고 중소기업 및 대기업 수준의 기업에 완벽한 백업 및 복구 솔루션을 제공하도록 설계되었습니다. Server2022 이상을 실행하는 사용자만 이 기능을 사용할 수 있습니다. 이 문서에서는 WindowsServerBackup을 설치, 제거 또는 재설정하는 방법을 설명합니다. Windows Server 백업을 재설정하는 방법 서버 백업에 문제가 있거나 백업에 너무 오랜 시간이 걸리거나 저장된 파일에 액세스할 수 없는 경우 Windows Server 백업 설정을 재설정하는 것을 고려할 수 있습니다. Windows를 재설정하려면

Oracle 인덱스 유형은 무엇입니까? Oracle 인덱스 유형은 무엇입니까? Nov 16, 2023 am 09:59 AM

Oracle 인덱스 유형은 다음과 같습니다. 1. B-트리 인덱스, 3. 함수 인덱스, 5. 역방향 키 인덱스, 7. 도메인 인덱스, 비트맵 연결 인덱스 10. 복합 인덱스. 세부 소개: 1. B-트리 인덱스는 동시 작업을 효율적으로 지원할 수 있는 자체 균형 트리 데이터 구조입니다. Oracle 데이터베이스에서 B-트리 인덱스는 가장 일반적으로 사용되는 인덱스 유형입니다. 2. 비트 그래프 인덱스는 인덱스 유형 기반입니다. 비트맵 알고리즘 등에 관한 것입니다.

Windows Server 2025 미리보기 버전은 업데이트를 환영하며 Microsoft는 내부자 테스트 경험을 개선합니다. Windows Server 2025 미리보기 버전은 업데이트를 환영하며 Microsoft는 내부자 테스트 경험을 개선합니다. Feb 19, 2024 pm 02:36 PM

Microsoft는 Windows Server 빌드 26040 버전을 출시하면서 제품의 공식 이름을 Windows Server 2025로 발표했습니다. Windows11WindowsInsiderCanaryChannel 버전 build26040도 출시되었습니다. 일부 친구들은 수년 전에 누군가 Windows NT를 워크스테이션 모드에서 서버 모드로 성공적으로 전환하여 다양한 버전의 Microsoft 운영 체제 간의 공통점을 보여주었다는 것을 아직도 기억할 것입니다. 마이크로소프트의 현재 서버 운영체제 버전과 윈도우 11 사이에는 뚜렷한 차이가 있지만, 세부 사항에 주목하는 사람들은 윈도우 서버가 왜 브랜드를 업데이트했는지,

인덱스가 배열 제한을 초과하는 문제를 해결하는 방법 인덱스가 배열 제한을 초과하는 문제를 해결하는 방법 Nov 15, 2023 pm 05:22 PM

해결 방법은 다음과 같습니다. 1. 인덱스 값이 올바른지 확인합니다. 먼저 인덱스 값이 배열의 길이 범위를 초과하는지 확인합니다. 배열의 인덱스는 0부터 시작하므로 최대 인덱스 값은 배열 길이에서 1을 뺀 값이어야 합니다. 2. 루프 경계 조건을 확인하세요. 루프에서 배열 액세스에 인덱스를 사용하는 경우 루프 경계 조건이 올바른지 확인하세요. 3. 배열 초기화: 배열을 사용하기 전에 배열이 올바르게 초기화되었는지 확인하십시오. 4. 예외 처리 사용: 프로그램의 예외 처리 메커니즘을 사용하여 인덱스가 배열 범위를 초과하는 오류를 잡을 수 있습니다. 그에 따라 처리하십시오.

웹 서버를 위장하기 위해 Nginx 버전 이름을 수정하는 방법 웹 서버를 위장하기 위해 Nginx 버전 이름을 수정하는 방법 May 14, 2023 pm 09:19 PM

nginx의 기본 이름을 수정하는 방법은 조금 위장하거나 설치할 수 있습니다. 팁: 일반적으로 수정은 nginx가 컴파일되기 전에 이루어집니다. 수정 후에는 scr/core/nginx.conf#definenginx_version"1.4.7"#definenginx_ver"nginx/"n과 같이 코드를 다시 컴파일해야 합니다.

인덱스를 통해 PHP 및 MySQL에서 데이터 그룹화 및 데이터 집계의 효율성을 향상시키는 방법은 무엇입니까? 인덱스를 통해 PHP 및 MySQL에서 데이터 그룹화 및 데이터 집계의 효율성을 향상시키는 방법은 무엇입니까? Oct 15, 2023 am 11:39 AM

인덱스를 통해 PHP 및 MySQL에서 데이터 그룹화 및 데이터 집계의 효율성을 향상시키는 방법은 무엇입니까? 소개: PHP와 MySQL은 현재 가장 널리 사용되는 프로그래밍 언어이자 데이터베이스 관리 시스템으로, 웹 애플리케이션을 구축하고 대용량 데이터를 처리하는 데 자주 사용됩니다. 데이터 그룹화 및 데이터 집계는 대용량 데이터를 처리할 때 흔히 수행되는 작업이지만, 인덱스를 적절하게 설계하고 사용하지 않으면 이러한 작업은 매우 비효율적일 수 있습니다. 이 기사에서는 인덱스를 사용하여 PHP 및 MySQL에서 데이터 그룹화 및 데이터 집계의 효율성을 향상시키는 방법을 소개하고,

See all articles