文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何从 Gorm 对象获取列名称和值?

2024-02-09 16:31

关注

php小编草莓在编程开发中,我们经常会使用Gorm对象进行数据库操作。而有时候,我们需要从Gorm对象中获取列名称和对应的值。那么,如何实现这个需求呢?在Gorm中,我们可以通过反射来获取对象的属性和值,并结合Gorm的标签来获取列名称。接下来,我将为大家详细介绍如何从Gorm对象中获取列名称和值的方法。让我们一起来看看吧!

问题内容

我想编写一个函数,它可以获取从数据库加载的任何对象(通过 gorm)并打印出所有列名称和值。显然,关键部分是将我的任何 Gorm 模型传递到此函数中的能力。我没有在下面展示这些,因为它们都很简单。

到目前为止,我拥有的是一个带有接口的函数,以及一些调用它的测试代码:

func testfunc(s interface{}) {

    // type
    v := reflect.TypeOf(s)

    fmt.Println(v)

    // fields?
    for i := 0; i < v.NumField(); i++ {
        fmt.Println(i)
    }
}
trans := make([]orm.Trans, 0)

    db.Where("state = ?", state.FINISHED).Limit(1).Find(&trans)

    testfunc(trans)

运行时,会打印出类型,然后出现恐慌:

[]orm.Trans
panic: reflect: call of reflect.Value.NumField on slice Value

我是个新手,所以欢迎你的想法。看来我可能的选择是:

谢谢。

解决方法

尝试这种方法:

func testfunc(x interface{}){
        v := reflect.ValueOf(x)
        s := reflect.TypeOf(x)
        names:=make([]interface{},v.NumField())
        values := make([]interface{}, v.NumField())

        for i := 0; i < v.NumField(); i++ {
                values[i] = v.Field(i).Interface()
                names[i] = s.Field(i).Name
        }
        fmt.Println("Names",names)
        fmt.Println("values",values)

}

1-您正在传递结构体切片。(如果使用切片,请避免在循环中调用上面的函数。)

2-我正在将此结构传递给上面的函数

x := struct {
                Name string
                Id int
        }{"Zargham", 2}

3-获取输出:-

Names [Name Id]
values [Zargham 2]

以上就是如何从 Gorm 对象获取列名称和值?的详细内容,更多请关注编程网其它相关文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯