【MySQL精通之路】全文搜索(7)-全文索引-添加用户定义的排序规则

 主博客:

【MySQL精通之路】全文搜索功能-CSDN博客


警告

不推荐使用用户定义的排序规则;

在MySQL的未来版本中将删除对它们的支持。
从MySQL 8.0.33开始,服务器会对SQL语句中使用COLLATE user_defined_collection发出警告;
当服务器启动时,“--collocation-server”设置为 等于用户定义的排序规则的名称时,也会发出警告。

 本节介绍如何使用内置全文分析器为全文搜索添加用户定义的排序规则

示例排序规则类似于latin_swedish_ci,但将“-”字符视为字母而非标点符号,以便将其作为单词字符进行索引。

“向字符集添加排序规则”提供了有关添加排序规则的一般信息;

假设您已经阅读并熟悉所涉及的内容。

要为全文索引添加排序规则,请使用以下过程。

此处的说明为简单字符集添加排序规则,“将排序规则添加到字符集”中所述,可以使用描述字符集属性的配置文件创建。对于复杂的字符集(如Unicode),请使用描述字符集属性的C源文件创建排序规则。


1.将排序规则添加到Index.xml文件中。用户定义排序规则允许的ID范围见第12.14.2节“选择排序规则ID”。该ID必须未使用,因此如果该ID已在您的系统中使用,请选择一个不同于1025的值。

<charset name="latin1">
...
<collation name="latin1_fulltext_ci" id="1025"/>
</charset>

2.在latin1.xml文件中声明排序规则的排序顺序。在这种情况下,可以从latin_swedish_ci复制订单:

<collation name="latin1_fulltext_ci">
<map>
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
10 11 12 13 14 15 16 17 18 19 1A 1B 1C 1D 1E 1F
20 21 22 23 24 25 26 27 28 29 2A 2B 2C 2D 2E 2F
30 31 32 33 34 35 36 37 38 39 3A 3B 3C 3D 3E 3F
40 41 42 43 44 45 46 47 48 49 4A 4B 4C 4D 4E 4F
50 51 52 53 54 55 56 57 58 59 5A 5B 5C 5D 5E 5F
60 41 42 43 44 45 46 47 48 49 4A 4B 4C 4D 4E 4F
50 51 52 53 54 55 56 57 58 59 5A 7B 7C 7D 7E 7F
80 81 82 83 84 85 86 87 88 89 8A 8B 8C 8D 8E 8F
90 91 92 93 94 95 96 97 98 99 9A 9B 9C 9D 9E 9F
A0 A1 A2 A3 A4 A5 A6 A7 A8 A9 AA AB AC AD AE AF
B0 B1 B2 B3 B4 B5 B6 B7 B8 B9 BA BB BC BD BE BF
41 41 41 41 5C 5B 5C 43 45 45 45 45 49 49 49 49
44 4E 4F 4F 4F 4F 5D D7 D8 55 55 55 59 59 DE DF
41 41 41 41 5C 5B 5C 43 45 45 45 45 49 49 49 49
44 4E 4F 4F 4F 4F 5D F7 D8 55 55 55 59 59 DE FF
</map>
</collation>

 3.修改latin1.xml中的ctype数组。将0x2D(“-”字符的代码)对应的值从10(标点符号)更改为01(大写字母)。在下面的数组中,这是第四行中的元素,从末尾算起第三个值。

<ctype>
<map>
00
20 20 20 20 20 20 20 20 20 28 28 28 28 28 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
48 10 10 10 10 10 10 10 10 10 10 10 10 01 10 10
84 84 84 84 84 84 84 84 84 84 10 10 10 10 10 10
10 81 81 81 81 81 81 01 01 01 01 01 01 01 01 01
01 01 01 01 01 01 01 01 01 01 01 10 10 10 10 10
10 82 82 82 82 82 82 02 02 02 02 02 02 02 02 02
02 02 02 02 02 02 02 02 02 02 02 10 10 10 10 20
10 00 10 02 10 10 10 10 10 10 01 10 01 00 01 00
00 10 10 10 10 10 10 10 10 10 02 10 02 00 02 01
48 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10
10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10
01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01
01 01 01 01 01 01 01 10 01 01 01 01 01 01 01 02
02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02
02 02 02 02 02 02 02 10 02 02 02 02 02 02 02 02
</map>
</ctype>

4.重新启动服务器。

5.要使用新的排序规则,请将其包含在要使用的列的定义中:

mysql> DROP TABLE IF EXISTS t1;
Query OK, 0 rows affected (0.13 sec)mysql> CREATE TABLE t1 (a TEXT CHARACTER SET latin1 COLLATE latin1_fulltext_ci,FULLTEXT INDEX(a)) ENGINE=InnoDB;
Query OK, 0 rows affected (0.47 sec)

6.测试排序规则以验证连字符是否被视为单词字符:

mysql> INSERT INTO t1 VALUEs ('----'),('....'),('abcd');
Query OK, 3 rows affected (0.22 sec)
Records: 3  Duplicates: 0  Warnings: 0mysql> SELECT * FROM t1 WHERE MATCH a AGAINST ('----' IN BOOLEAN MODE);
+------+
| a    |
+------+
| ---- |
+------+
1 row in set (0.00 sec)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/17473.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

重庆耶非凡科技有限公司有选品师项目培训吗?

在当今科技飞速发展的时代&#xff0c;各种科技公司如雨后春笋般涌现&#xff0c;它们在不同领域发挥着重要作用。其中&#xff0c;重庆耶非凡科技有限公司以其独特的业务模式和专业服务&#xff0c;在业界赢得了良好的口碑。那么&#xff0c;重庆耶非凡科技有限公司究竟是做什…

JavaScript(ES5) 入门

01-简介 1)JavaScript 发展史 [1] 1995年,navigator(导航者),netscape(网景);用户体验性特别好 [2] 表单验证难题,表单验证都是在后台处理.当时处在网速特别慢的时代,发送一个请求,接收响应 需要5分钟左右的时候提高表单验证的速度,想开发一种语言在前端进行表单验证. [3] 1995…

2023年企业的图纸是如何通过透明加密技术进行数据防泄密

随着网络信息化及移动互联网时代的到来&#xff0c;电脑及互联网成来了现在设计行业制作业不可缺少的工作载体&#xff0c;企业的核心数据设计图纸、文档内容&#xff0c;研发技术资料等都存在员工的电脑上&#xff0c;及企业的网络设备之中&#xff0c;所以企业图纸数据资料使…

Python开发 —— 错误ModuleNotFoundError: No module name

1. 主要错误代码 import syssys.path.append("../Signal_Capture_Decoding")import spysys.path.append("../SPI_converter")import command 2. 错误 Traceback (most recent call last):File "C:\Desktop\WaveFormsSDK\samples\develop\main.py&q…

java高级——String字符串探索(在jvm底层中如何实现,常量池中怎么查看)

java高级——String字符串探索&#xff08;在jvm底层中如何实现&#xff0c;常量池中怎么查看&#xff09; 文章介绍提前了解的知识点1. 常量池2. Jvm虚拟机3. 字节码 String类详解1. String对象在申明后将不可修改&#xff0c;是不可变类2. String进行相加相减等操作时一定会创…

【ARM+Codesys案例】树莓派+Codesys软PLC方案在包装行业灌装旋盖机的应用

ARM系列支持&#xff1a;全志T3、RK3568、树莓派 机型定义&#xff1a;双工位旋盖机 旋盖机主要适用于不同规格的材质及不同规格的盖、旋&#xff08;轧&#xff09;盖。适用螺旋盖、防盗盖、防撞盖、压入盖等。压力可方便调整&#xff0c;根据瓶盖大小设置取盖位。结构紧凑、…

Linux--进程间通信(2)(有名管道)

目录 1.原理 2.创建命名管道 3.使用命名通道实现简单的通信 4.使用创建的命名管道 1.原理 匿名管道没有名称&#xff0c;它们是通过句柄在父进程和子进程之间传递的。这意味着匿名管道只能用于具有父子关系的进程之间。 但如果程序之间没关系&#xff0c;那么这时候就要用…

2024 年“泰迪杯”A 题:生产线的故障自动识别与人员配置--第四题(用遗传算法解决生产线排班问题--matlab代码)

问题背景&#xff1a; 问题四&#xff1a;根据实际情况&#xff0c;现需要扩大生产规模&#xff0c;将生产线每天的运行时间从 8 小时增加 到 24 小时不间断生产&#xff0c;考虑生产线与操作人员的搭配&#xff0c;制定最佳的操作人员排班方案&#xff0c;要求满足以下条件&am…

RedHat9网络配置设计

目录 一、实验目的 二、实验过程 1、配置新网络接口 2、多网卡配置网络 3、网络接口的绑定&#xff0c;进行远程访问 4、配置网络接口的组合 一、实验目的 本次实验的目的是使用nmcli命令工具配置网络&#xff0c;ens160配置多个网卡&#xff0c;进行网络接口的绑定与组合…

使用“tcpdump”查看原始数据包

使用“tcpdump”查看原始数据包 尽管像 Snort 这样的工具可以出色地筛选通过我们网络的所有内容&#xff0c;但有时需要查看原始数据。为此&#xff0c;我们最好的工具是“tcpdump”。 使用 tcpdump 的最基本方法是简单地发出以下命令&#xff1a; tcpdump 使用 -v 选项可以…

Redis 主从搭建简单教程

安装单机 首先拿到安装包 wget https://download.redis.io/releases/redis-7.0.15.tar.gz然后进行解压 tar -zxvf redis-7.0.15.tar.gz 然后创建一个文件夹myredis将原始配置文件进行备份 mkdir /myrediscp redis.conf /myredis/redis7.conf 将配置文件复制进去 最后使用vim编…

mysql的MyISAM存储引擎

MyISAM是MySQL的一种非事务性存储引擎,曾经是MySQL的默认存储引擎。虽然现在InnoDB成为了默认存储引擎,但MyISAM仍然有其独特的优势和适用场景。以下是对MyISAM存储引擎的详细介绍: 特性 表级锁定: MyISAM使用表级锁定,这意味着在对表进行读写操作时,会锁定整个表。读写…

室内也可以用北斗定位?还能用RTK?

室内卫星顾名思义&#xff0c;就是在室内有遮挡环境中的卫星定位技术&#xff0c;众所周知&#xff0c;目前全球几大GNSS定位系统已经很完善&#xff0c;但是GNSS有个致命的弱点&#xff0c;就是地面如果有遮挡就没有信号&#xff0c;在这样的条件下&#xff0c;在室内定位场景…

#微信#经验分享

七燕论文是一款非常好用的论文写作工具&#xff0c;不仅在查重降重方面表现出色&#xff0c;而且还具有方便、快捷的特点&#xff0c;是广大学生和研究人员的理想选择。 首先&#xff0c;七燕论文在查重降重方面非常靠谱。它能够帮助用户快速检测论文的原创度&#xff0c;提供…

使用selenium打开浏览器之后,有浏览器内部的提示设置默认浏览器等,怎么屏蔽或关闭这些提示

当使用Selenium打开浏览器时&#xff0c;可能会遇到浏览器内部的一些提示或弹窗&#xff0c;例如设置默认浏览器的提示。你可以通过配置选项或设置浏览器参数来屏蔽或关闭这些提示。 以下是针对不同浏览器的一些方法&#xff1a; 对于Chrome浏览器&#xff1a; 在创建Chrome…

RT_Thread内核源码分析(一)——CM3内核和上下文切换

目录 一、程序存储分析 1.1 CM3内核寻址空间映射 1.2 程序静态存储和动态执行 二、CM3内核相关知识 2.1 操作模式和特权极别 2.2 环境相关寄存器 2.2.1 通用寄存器组&#xff0c; 2.2.2 状态寄存器组 2.2.3 模式切换环境自动保存 2.2.4 函数调用形参位置 2.3 …

mysql INSERT INTO时的锁

mysql INSERT INTO时的默认锁 MySQL中的INSERT INTO语句默认使用的是表锁,而不是行锁。表锁是在执行INSERT INTO操作时直接锁定整个表,确保在同一时间只有一个线程可以对表进行写操作。 使用行锁来处理INSERT INTO操作 方式一 使用事务(BEGIN开启事务,COMMIT提交事务)…

SQL数据库创建用户及赋予权限

1.理论 创建登录名 CREATE LOGIN [登入名LoginName] WITH PASSWORD ‘YourPassword’; – 创建用户 CREATE USER [UserName] FOR LOGIN [登入名LoginName]; – 授予权限 GRANT EXECUTE ON [YourStoredProcedure] TO [YourUserName]; – 允许执行指定的存储过程 GRANT SELEC…

Petalinux 基础操作流程总结

Petalinux 工作环境&#xff1a; ● Petalinux 软件安装 ● “/bin/sh” 需要是 bash&#xff0c;系统默认可能是 dash&#xff0c;需要修改 ● 不能在共享文件夹创建 petalinux 工程 ● 使用 petalinux 命令前需要设置 petalinux 环境变量&#xff1a;source /settings.sh创建…

信息安全基础(补充)

&#xff09;的内容主要有数据备份、数据修复、系统恢复等。响应&#xff08;Respons&#xff09;的内容主要有应急策略、应急机制、应急手段、入侵过程分析及安全状态评估等。 面向数据挖掘的隐私保护技术主要解决高层应用中的隐私保护问题&#xff0c;致力于研究如何根据不同…