登录
首页 >  Golang >  Go问答

go-pg“在”同一张表中的 2 个字段

来源:stackoverflow

时间:2024-03-04 22:30:22 100浏览 收藏

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《go-pg“在”同一张表中的 2 个字段》,文章讲解的知识点主要包括,如果你对Golang方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

问题内容

我正在使用 https://github.com/go-pg/pg 来处理这些东西,在建立基本的归属关系时遇到了巨大的问题。

所以基本上我有一个表,其中包含列receipient_id和sender_id,两者都指向同一个用户表。这是我的代码和结果:

type transaction struct {
    id              int
    receipient      *user  `json:"receipient_id" sql:"-" validate:"required"`
    sender          *user  `json:"sender_id" sql:"-" validate:"required"`
    transactiontype int    `json:"transaction_type" validate:"required"`
    status          int    `json:"status" validate:"required"`
    ammount         int    `json:"ammount" validate:"required"`
    createdat       string `json:"created_at" validate:"required"`
}



err = database.dbcon.model(&transactions).select()
if err != nil {
    return transactions, err
}



16:51:15.754 v1transactionlistpost ▶ erro 006 supppers [transaction sender: transaction_type:0 status:1 ammount:100 created_at:1533650239
]
2018/08/07 16:51:15 http: panic serving [::1]:50157: runtime error: invalid memory address or nil pointer dereference
goroutine 5 [running]:
net/http.(*conn).serve.func1(0xc42036fd60)
 ...

这是实际的数据库:

SELECT * FROM transactions;
-[ RECORD 1 ]----+-----------
id               | 1
receipient_id    | 23
sender_id        | 24
transaction_type | 0
status           | 1
ammount          | 100
created_at       | 1533650239


SELECT * FROM users;
-[ RECORD 1 ]---------+-------------------------------------------------------------
id                    | 23
email                 | [email protected]
username              | damn here
password              | $2a$10$ABBHfgwhnepqKitBoiQ2bOcPfGjUIjio33uL52R88Lk2XhcfGwn26
user_type             | 2
profile_id            | 1
status                | 2
confirm_token         |
recover_token         |
recover_token_expiry  |
recover_secret_answer | $2a$10$xPwZk2LanxXf1lvCvp29IuyHav88m5dGXo8Ao0f5A1aV1zwh5t6le
-[ RECORD 2 ]---------+-------------------------------------------------------------
id                    | 24
email                 | [email protected]
username              | removeusername
password              | $2a$10$1tmCvZy5xo5zGz9C3g6YeeV8Wb149VwSTFhT1pcjb0zVasT.fbTKy
user_type             | 2
profile_id            | 1
status                | 2
confirm_token         |
recover_token         |
recover_token_expiry  |
recover_secret_answer | $2a$10$CeS5qgITVGBgWX7cumhbdOoAPOhg/Lc2NXDu.nY5RzK3PGCW26Ik2

解决方案


我忘记添加 id 列,这是一个工作示例:

type Transaction struct {
    Id              int
    RecipientId     int    `json:"recipient_id"`
    Recipient       *User  `pg:"fk:recipient_id"`
    SenderId        int    `json:"sender_id"`
    Sender          *User  `pg:"fk:sender_id"`
    TransactionType int    `json:"transaction_type" validate:"required"`
    Status          int    `json:"status" validate:"required"`
    Ammount         int    `json:"ammount" validate:"required"`
    CreatedAt       string `json:"created_at" validate:"required"`
}

理论要掌握,实操不能落!以上关于《go-pg“在”同一张表中的 2 个字段》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

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