登录
首页 >  Golang >  Go问答

如何在 xorm 中将 mapinterface{} 转换为指定结构?

来源:stackoverflow

时间:2024-02-19 20:54:21 309浏览 收藏

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《如何在 xorm 中将 mapinterface{} 转换为指定结构?》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

问题内容

我有一个数据库查询,它返回一个额外的计算列以及所有映射的结构列。我想将其映射回结构,同时还能够提取不属于结构的计算列。我可以通过使用 xorm QueryInterface() 函数来获取所有内容,但我似乎找不到如何将生成的 map[string]interface{} 转换回结构...

有什么想法吗?我看到 gorm 有 db.Model(...).Create(...) 但似乎在 xorm 中找不到等效项。


正确答案


嗯,我找到了一个解决方案,虽然不是一个优雅的解决方案,但我希望有更好的东西,所以如果其他人有一个好的答案......

我基本上只是决定使用 json marshal,然后使用 unmarshal 来获取 map[string]interface{} 并将其返回到结构中。这意味着我必须在结构上使用一堆 json:"..." 标签,因为 column->property 映射与 xorm 使用的映射不同。有点难看,但它允许我从数据库查询中捕获额外的道具。

type MyStruct struct {
    ID                   int64              `xorm:"primaryKey"`
    ProductID            int64              `xorm:"INDEX" json:"product_id"`
    Index                int64              `xorm:"INDEX NOT NULL DEFAULT 0"`
    Code                 string             `xorm:"-" json:"code"`
}

func (b *MyDBStruct) FromMap(src map[string]interface{}) error {
    jsonStr, _ := json.Marshal(src)
    err := json.Unmarshal(jsonStr, &b)
    if err == nil {
        for key := range src {
            b.AfterSet(key, nil)
        }
    }
    return err
}

好了,本文到此结束,带大家了解了《如何在 xorm 中将 mapinterface{} 转换为指定结构?》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>