全文索引与虚拟列索引需要注意的事项

2024-09-06 14:20

本文主要是介绍全文索引与虚拟列索引需要注意的事项,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 MySQL 中,全文索引 (FULLTEXT)UNION ALL 可以一起使用,但有一些限制和注意事项。

限制与问题:

  1. 全文索引不能直接在 UNION ALL 中使用:MySQL 不允许在多个查询的 UNIONUNION ALL 操作中使用 MATCH ... AGAINST,因为每个 SELECT 语句都是独立处理的。如果你想在多个表上进行全文搜索,并且想使用 UNION ALL,全文搜索需要在各自的查询中独立进行。

  2. MATCH ... AGAINST 的限制:当你在 UNION ALL 中使用时,MySQL 不能在 UNION 操作后再应用 MATCH,这意味着你不能对组合后的结果进行全文搜索。

解决方案:

要解决这个问题,通常有两种做法:

方法 1: 在每个 SELECT 子查询中单独使用 MATCH ... AGAINST

你可以在每个表的查询中分别使用 MATCH ... AGAINST,而不是对整个 UNION ALL 的结果进行全文搜索。

示例:

sql

CREATE TEMPORARY TABLE temp_results AS
SELECT p1.*
FROM cdr_voice_202409_0 AS p1
WHERE LENGTH(p1.calling_number) < 11
UNION ALL
SELECT p1.*
FROM cdr_voice_202408_0 AS p1
WHERE LENGTH(p1.calling_number) < 11
UNION ALL
SELECT p1.*
FROM cdr_voice_202407_0 AS p1
WHERE LENGTH(p1.calling_number) < 11;

在此方法中,每个表的查询单独使用全文索引进行搜索,MATCH ... AGAINST 会分别作用于每个表的数据。

方法 2: 使用临时表

如果你需要对多个表的结果进行全文搜索,可以将结果存储在临时表中,然后对该临时表进行 MATCH ... AGAINST 操作。虽然这稍微复杂一些,但在某些场景下能提高查询的灵活性。

示例:
  1. 首先将查询结果插入到临时表中:

     sql 

    CREATE TEMPORARY TABLE temp_results AS S
    ELECT p1.* FROM 
    cdr_voice_202409_0 AS p1 
    WHERE LENGTH(p1.calling_number) < 11 
    UNION ALL 
    SELECT p1.* FROM 
    cdr_voice_202408_0 AS p1 
    WHERE LENGTH(p1.calling_number) < 11 
    UNION ALL 
    SELECT p1.* 
    FROM cdr_voice_202407_0 AS p1 
    WHERE LENGTH(p1.calling_number) < 11;

  2. 然后对临时表使用全文索引:

    SELECT * FROM temp_results WHERE MATCH(calling_number) AGAINST('10086') LIMIT 1000 OFFSET 0;

    在数据库中添加一个虚拟列(例如 MySQL 的 VIRTUAL 生成列)后,这个列通常不会自动出现在 Java 或其他编程语言中的实体类中,尤其是在使用 ORM(如 Hibernate 或 MyBatis)时。实体类中的字段是基于数据库表中物理存在的列定义的,而虚拟列可能只在数据库计算时存在,不会自动映射到实体类中。

总结:

  • 全文索引不能跨 UNION ALL 直接使用,你需要在每个 SELECT 中分别使用 MATCH ... AGAINST
  • 如果需要对合并后的结果进行全文搜索,可以通过临时表来实现。

这篇关于全文索引与虚拟列索引需要注意的事项的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142250

相关文章

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

VMWare报错“指定的文件不是虚拟磁盘“或“The file specified is not a virtual disk”问题

《VMWare报错“指定的文件不是虚拟磁盘“或“Thefilespecifiedisnotavirtualdisk”问题》文章描述了如何修复VMware虚拟机中出现的“指定的文件不是虚拟... 目录VMWare报错“指定的文件不是虚拟磁盘“或“The file specified is not a virt

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

Python中列表的高级索引技巧分享

《Python中列表的高级索引技巧分享》列表是Python中最常用的数据结构之一,它允许你存储多个元素,并且可以通过索引来访问这些元素,本文将带你深入了解Python列表的高级索引技巧,希望对... 目录1.基本索引2.切片3.负数索引切片4.步长5.多维列表6.列表解析7.切片赋值8.删除元素9.反转列表

MySQL的索引失效的原因实例及解决方案

《MySQL的索引失效的原因实例及解决方案》这篇文章主要讨论了MySQL索引失效的常见原因及其解决方案,它涵盖了数据类型不匹配、隐式转换、函数或表达式、范围查询、LIKE查询、OR条件、全表扫描、索引... 目录1. 数据类型不匹配2. 隐式转换3. 函数或表达式4. 范围查询之后的列5. like 查询6

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测