go语言中的Redis缓存相关代码接口的设计

发布于 2022-09-06 15:55:56 字数 864 浏览 22 评论 0

系统中有一些数据量不大且几乎不变的的数据表,数据表命名都以"L_"开头,以下简称L表。
需求:通过Redis缓存将L表数据缓存起来以提升系统响应速度
目前设计方案:

  1. 初始Redis时全量缓存
  2. Redis存储数据结构为K-V,

Key := TableName : id : name
通过这样设计Key的方式用以支持FindByID和FindByName的模糊查询
目前get方法的设计如下:

func GetData(key string) (string, error) {
    return Get(key)
}

func GetKeys(pattern string) ([]string, error) {
    return Keys(pattern)
}

func FindById(table_name string, id int64) (string, error) {
    var q Query
    q.TableName = table_name
    q.ID = id
    pattern := q.TableName + ":" + strconv.FormatInt(q.ID, 10) + "*"
    key, _ := GetKeys(pattern)
    return GetData(key[0])
}

问题:

本人Go和Redis都是初学,做了如上设计,但是由于后期需要FindBy更多字段,由于表格式的变换,Query的数据类型也有多种可能,现在的设计难以支持扩展,想问下大家相关设计经验,我应该怎样设计Get方法更好?
还望大家不吝赐教,谢谢大家!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文