Go语言操作RediSearch进行搜索方法示例详解

 更新时间:2023年12月18日 14:13:22   作者:guoqiang  
这篇文章主要为大家介绍了Go语言操作RediSearch进行搜索方法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

引言

RediSearch是一个支持搜索功能的redis模块。本文对此模块进行了介绍,并用go语言实现了一个简单示例。

RediSearch提供了查询、二级索引、全文索引功能。你需要先在相关Redis条目上建立索引,然后才能使用RediSearch进行查询。

RediSearch使用了压缩算法和倒序索引算法,使得其在性能和内存占用上都有很好的表现。它可以支持精确匹配、模糊匹配、数字过滤等功能。

docker-compose方式安装

新建docker-compose.yml文件,内容如下:

# redis-stack
version: '3.1'
services:
  redis-stack:
    image: redis/redis-stack-server:latest
    ports:
      - 6380:6379
    volumes:
      - ./data:/data

执行命令来启动容器:

docker-compose up -d

用Go语言操作RediSearch

redissearch-go是一个支持RediSearch的go语言客户端,使用起来很简单。下面写一个简单的示例:

func TestRedisSearch(t *testing.T) {
    // 连接
    conn := redisearch.NewClient("localhost:6380", "tangshi")
    // 定义索引
    sc := redisearch.NewSchema(redisearch.DefaultOptions).AddField(redisearch.NewTextFieldOptions("title", redisearch.TextFieldOptions{Weight: 5.0, Sortable: true})).AddField(redisearch.NewTextField("content"))
    // 删除现有索引
    conn.Drop()
    // 创建索引
    err := conn.CreateIndex(sc)
    assert.Equal(t, err, nil)
    // 添加文档
    doc1 := redisearch.NewDocument("doc1", 1.0)
    doc1.Set("title", "春晓").Set("content", "春眠不觉晓,处处闻啼鸟。夜来风雨声,花落知多少。")
    doc2 := redisearch.NewDocument("doc2", 1.0)
    doc2.Set("title", "春夜喜雨").Set("content", "好雨知时节,当春乃发生。随风潜入夜,润物细无声。")
    doc3 := redisearch.NewDocument("doc3", 1.0)
    doc3.Set("title", "春夜洛城闻笛").Set("content", "谁家玉笛暗飞声,散入春风满洛城。此夜曲中闻折柳,何人不起故园情。")
    doc4 := redisearch.NewDocument("doc4", 1.0)
    doc4.Set("title", "江雪").Set("content", "千山鸟飞绝,万径人踪灭。孤舟蓑笠翁,独钓寒江雪。")
    doc5 := redisearch.NewDocument("doc5", 1.0)
    doc5.Set("title", "望庐山瀑布").Set("content", "日照香炉生紫烟,遥看瀑布挂前川。飞流直下三千尺,疑是银河落九天。")
    // 为索引添加文档
    err = conn.IndexOptions(redisearch.DefaultIndexingOptions, []redisearch.Document{doc1, doc2, doc3, doc4, doc5}...)
    assert.Equal(t, err, nil)
    time.Sleep(time.Millisecond * 100)
    // 搜索 瀑布
    docs, total, err := conn.Search(redisearch.NewQuery("*瀑布*").Limit(0, 5).SetReturnFields("title", "content"))
    assert.Equal(t, err, nil)
    assert.Equal(t, total, 1)
    assert.Equal(t, docs[0].Properties["title"], "望庐山瀑布")
    // 搜索 春
    docs, total, err = conn.Search(redisearch.NewQuery("*春*").Limit(0, 5).SetReturnFields("title", "content").SetSortBy("title", true))
    assert.Equal(t, err, nil)
    assert.Equal(t, total, 3)
    assert.Equal(t, docs[0].Properties["title"], "春夜喜雨")
    for _, item := range docs {
        t.Log(item.Properties["title"], item.Properties["content"])
    }
}

在上面的代码中,我们创建了一个名为tangshi的索引,然后添加了5个文档。接下来,我们分别搜索了 瀑布 和 春,并测试了搜索结果。

RediSearch使用场景

和Eleasticsearch、Solr等搜索引擎相比,RediSearch的功能还是比较简单的,它并不是要替代这些专业的搜索引擎,并不适用于所有场景。
它主要适用于以下一些场景:

  • 数据量不大,所有索引内容可以被放进内存中。由于redis的数据都存储在内存中,如果索引数据内容过大,可能不适合使用RediSearch。
  • Ephemeral indexing,即临时索引,索引内容不需要长期存储。

如果有想详细了解的,可以查阅一下下面列出的参考资料。

参考资料

以上就是Go语言操作RediSearch进行搜索方法示例详解的详细内容,更多关于Go操作RediSearch搜索的资料请关注脚本之家其它相关文章!

相关文章

  • Redis高并发情况下并发扣减库存项目实战

    Redis高并发情况下并发扣减库存项目实战

    本文主要介绍了Redis高并发情况下并发扣减库存项目实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Redis发布订阅和实现.NET客户端详解

    Redis发布订阅和实现.NET客户端详解

    发布订阅在应用级其作用是为了减少依赖关系,通常也叫观察者模式。主要是把耦合点单独抽离出来作为第三方,隔离易变化的发送方和接收方。下面这篇文章主要给大家介绍了关于Redis发布订阅和实现.NET客户端的相关资料,需要的朋友可以参考下
    2017-03-03
  • Redis中SDS简单动态字符串详解

    Redis中SDS简单动态字符串详解

    Redis中的SDS(Simple Dynamic String)是一种自动扩容的字符串实现方式,它可以提供高效的字符串操作,并且支持二进制安全。SDS的设计使得它可以在O(1)时间内实现字符串长度的获取和修改,同时也可以在O(N)的时间内进行字符串的拼接和截取。
    2023-04-04
  • Redis 在真实世界的 5 个用法

    Redis 在真实世界的 5 个用法

    Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API这篇文章主要介绍了Redis 在真实世界的 5 个用法,需要的朋友可以参考下
    2018-03-03
  • Centos7.3安装Redis4.0.6详细图文教程

    Centos7.3安装Redis4.0.6详细图文教程

    这篇文章主要介绍了Centos7.3安装Redis4.0.6详细教程图解,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-10-10
  • Redis集群增加节点与删除节点的方法详解

    Redis集群增加节点与删除节点的方法详解

    这篇文章主要给大家介绍了关于Redis集群增加节点与删除节点的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • redis数据的两种持久化方式对比

    redis数据的两种持久化方式对比

    Redis是我们开发中常用的数据库,今天和大家分享的就是redis持久化的2种方式:RDB(Redis DataBase)和AOF(Apend Only File),希望对大家学习redis有帮助,一起来看看吧。
    2017-08-08
  • Redis 定长队列探索及实践

    Redis 定长队列探索及实践

    这篇文章主要介绍了Redis 定长队列探索及实践,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • 分布式锁三种实现方式及对比

    分布式锁三种实现方式及对比

    这篇文章主要介绍了分布式锁三种实现方式及对比,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • redislive监控redis服务的图文教程_动力节点Java 学院整理

    redislive监控redis服务的图文教程_动力节点Java 学院整理

    这篇文章主要介绍了redislive监控redis服务的图文教程_动力节点Java 学院整理,需要的朋友可以参考下
    2017-08-08

最新评论