doutang7414 2019-06-09 04:14 采纳率: 0%
浏览 138

Sqlboiler仅获取所需的列

I am trying to follow the examples in sqlboiler (https://github.com/volatiletech/sqlboiler). But couldn't find a way to get just the columns queried in the select statement?

users, err := models.Users(
  Select("id", "name"),
  Where("age > ?", 30),
).All(ctx, db)

In this example, .All returns entire tuple containing empty/nil values of columns not queried. I was wondering if there is a way to return a map/list (or any relevant data structure/format) of just the queried columns. Thanks!

  • 写回答

1条回答 默认 最新

  • dongyou6909 2019-06-11 23:24
    关注

    You get all the fields, because you get instances of models.User, which have all the fields, you want them or not.

    One thing you can do is write your own cut-down User struct, and bind to that.

    type LiteUser struct {
      ID int `boil:"id"`
      Name string `boil:"name"`
    }
    
    var users []*LiteUser
    err := models.Users(
      Select("id", "name"),
      Where("age > ?", 30),
    ).Bind(ctx, db, &users)
    
    评论

报告相同问题?

悬赏问题

  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码