3

私はgorm ( go o orm ) を使用して、JSON でエンコードされるデータベースからデータを取得しています。Gorm は、主キーと時間追跡用のデフォルトの構造体を提供します。この構造体の DeletedAt 属性は、JSON でエンコードされるべきではありません。

パスワードを出力しない小さな例を書きましたが、DeletedAt 属性は引き続き表示されます。

package main

import (
    "encoding/json"
    "fmt"
    "os"

    "github.com/jinzhu/gorm"
    _ "github.com/lib/pq"
    _ "github.com/mattn/go-sqlite3"
)

// Struct from the gorm package:
//
// type Model struct {
//     ID        uint `gorm:"primary_key"`
//     CreatedAt time.Time
//     UpdatedAt time.Time
//     DeletedAt *time.Time
// }

// Defines the database model for gorn
type User struct {
    gorm.Model
    Username string `json:"username" sql:"size:32; not null; unique"`
    Password string `json:"password" sql:"not null"`
    Locale   string `json:"locale"   sql:"not null"`
}

// Public JSON version of database model
type PublicUser struct {
    *User
    DeletedAt bool `json:"deletedAt,omitempty"`
    Password  bool `json:"password,omitempty"`
}

func main() {
    db, err := gorm.Open("sqlite3", "storage.db")

    if err != nil {
        fmt.Println(err)
    }

    u := &User{}
    db.Where("id = ?", 3).Find(&u)

    json.NewEncoder(os.Stdout).Encode(PublicUser{
        User: u,
    })
}

これは、スクリプトを実行した場合に得られる ourput です。

{
    "ID":3,
    "CreatedAt":"2015-05-13T14:54:23.5577227Z",
    "UpdatedAt":"2015-05-13T14:54:23.5577227Z",
    "DeletedAt":null,
    "username":"dan",
    "locale":"en_US"
}

Alfred Rossi の例を変更して動作を模倣したところ、同じ結果が得られました。

4

1 に答える 1

2

bool を false に設定してフィールドをシャドウし、タグを付けることができますomitempty

例えば

type User struct {
    Username  string `json:"username"`
    DeletedAt int    `json:"deleted_at"`
}

type PublicUser struct {
    *User
    DeletedAt bool `json:"deleted_at,omitempty"`
}

ここで 自由 に 遊ん でください. Attila Oláh のこのブログ投稿も参照してください。

于 2015-05-10T13:15:44.513 に答える