返回顶部
首页 > 资讯 > 精选 >如何为同名的嵌套字段创建文本索引
  • 442
分享到

如何为同名的嵌套字段创建文本索引

2024-02-09 21:02:55 442人浏览 安东尼
摘要

PHP小编草莓将为大家介绍如何在同名的嵌套字段中创建文本索引。在数据库中,我们常常会遇到需要在嵌套字段中进行搜索和查询的情况。然而,当存在多个同名的嵌套字段时,创建文本索引就会变得复杂

PHP小编草莓将为大家介绍如何在同名的嵌套字段中创建文本索引。在数据库中,我们常常会遇到需要在嵌套字段中进行搜索和查询的情况。然而,当存在多个同名的嵌套字段时,创建文本索引就会变得复杂。本文将详细讲解如何应对这个问题,为大家提供解决方案。接下来,我们将一步步引导您完成这个过程,让您轻松地为同名的嵌套字段创建文本索引。

问题内容

我正在尝试在具有相同名称的 2 个嵌套字段上创建复合文本索引。我尝试这样做的原因是我可以在两个字段上使用 monGo 执行全文搜索。

数据结构示例

{
    "createdat": "2023-01-20t18:39:45.551z",
    "id": "63cadff13fc409d0b026f219",
    "userid": "63c13a9ba4c921b78e7d1a3a",
    "question": {
        "statement": "what is the atomic number of potassium?",
        "fileurl": "Http://localhost:4000/media/90152d8363424e688ad6e9505194a818.jpg",
        "mediatype": 2
    },
    "answer": {
        "statement": "19"
    }
}

从示例中可以看到,questionanswer 具有相同的嵌套字段 statement我正在尝试为问题和答案语句建立文本索引

我尝试做什么

    textsearchindexmodel := mongo.indexmodel{
        keys: bson.d{
            {value: "question.statement", key: "text"},
            {value: "answer.statement", key: "text"},
        },
        options: options.index().setname("textsearchindex"),
    }

这不起作用并产生了此错误:

Failed to create index for flashcard collection:....caused by :: 
The field 'text' appears multiple times in the index key pattern
  • 有办法做到这一点吗?
  • 我的方法对于我想要实现的目标来说是正确的吗?

p.s:如果您不熟悉 go,您也可以上传它在 mongodb 上的方式,因为到 mongodb go 驱动程序的映射非常简单

解决方法

请注意,一个集合最多可以有一个文本索引.

如果您知道这一点并且想要创建一个涵盖 "question.statement""answer.statement" 的文本索引,那么这是可行的。

您的错误是索引规范: bson .d 表示一个文档,一个有序的属性列表(名称-值对)。这是 bson.e 的一部分,其中 bson. e 是:

type e struct {
    key   string
    value interface{}
}

key 是属性的名称,value 是该属性的值。所以你把它倒过来了,它应该是:

textSearchIndexModel := mongo.IndexModel{
    Keys: bson.D{
        {Key: "question.statement", Value: "text"},
        {Key: "answer.statement", Value: "text"},
    },
    Options: options.Index().SetName("textSearchIndex"),
}

以上就是如何为同名的嵌套字段创建文本索引的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: 如何为同名的嵌套字段创建文本索引

本文链接: https://lsjlt.com/news/562814.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何为同名的嵌套字段创建文本索引
    php小编草莓将为大家介绍如何在同名的嵌套字段中创建文本索引。在数据库中,我们常常会遇到需要在嵌套字段中进行搜索和查询的情况。然而,当存在多个同名的嵌套字段时,创建文本索引就会变得复杂...
    99+
    2024-02-09
  • Mysql为json字段创建索引的两种方式
    目录 一、前言二、通过虚拟列添加索引(Secondary Indexes and Generated Columns)三、多值索引(Using multi-valued Indexes)四、官...
    99+
    2023-09-24
    mysql json 数据库
  • PostgreSQL如何快速给指定表每个字段创建索引
    小编给大家分享一下PostgreSQL如何快速给指定表每个字段创建索引,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们...
    99+
    2024-04-02
  • 如何为Mongodb创建唯一的pair索引?
    php小编西瓜为您介绍如何为Mongodb创建唯一的pair索引。Mongodb是一款非关系型数据库,而pair索引则是一种特殊的索引类型,用于确保集合中的文档对的唯一性。要创建唯一的...
    99+
    2024-02-10
  • SAP S/4HANA系统上如何创建扩展字段的业务上下文
    这期内容当中小编将会给大家带来有关SAP S/4HANA系统上如何创建扩展字段的业务上下文,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Fiori UI可以扩展的前提条件之一是,它应该在tcode SCF...
    99+
    2023-06-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作