1

データベースから JSON データを取得しようとすると、次のようになります:
{"time":"13:42:21 11.12.14",":":"Привет"}
{"time":"13:42 :25 11.12.14",":":"Эй!"}

var time string 
var text string

type chatbetweenusers struct {
    Time string `json:"time"`
    Text string `json:":"text"`
    }

var buffer bytes.Buffer
    db, err := sql.Open("sqlite3", "./database.db"); if err != nil {
        log.Fatal(err)
    }; defer db.Close()

rows, err := db.Query("select time, text from messages;")
    if err != nil {
        log.Fatal(err) 
    } 
    defer rows.Close()


    for rows.Next() {
        // give a names for every column from query result
        err := rows.Scan(&time, &text)
        if err != nil {
            log.Fatal(err)
        }
        // add strings to struct
        chatitem := &chatbetweenusers{time, text}
        log.Println(chatitem)

        // format it to JSON!
        b, err := json.Marshal(chatitem)
        // conver JSON into string to return from Martini
        s := string(b[:])
        buffer.WriteString(s)
    }

return buffer.String()
})

データベースから他のデータを取得しようとすると、次のようになります:
{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{ }{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}

var text string
var user1 string

type chatbetweenusers struct {
    Text string `json:":"text"`
    User1 string `json:":"user1"`
    }

var buffer bytes.Buffer
    db, err := sql.Open("sqlite3", "./database.db"); if err != nil {
        log.Fatal(err)
    }; defer db.Close()

rows, err := db.Query("select text, user1 from messages;")
    if err != nil {
        log.Fatal(err) 
    } 
    defer rows.Close()


    for rows.Next() {
        // give a names for every column from query result
        err := rows.Scan(&text, &user1)
        if err != nil {
            log.Fatal(err)
        }
        // add strings to struct
        chatitem := &chatbetweenusers{text, user1}
        log.Println(chatitem)

        // format it to JSON!
        b, err := json.Marshal(chatitem)
        // conver JSON into string to return from Martini
        s := string(b[:])
        buffer.WriteString(s)
    }

return buffer.String()
})

JSON で他のデータを合成するとどうなりますか? 可能なことはすべて試しましたが、これは正しく機能しません。

4

1 に答える 1

1

構造を定義する方法を検討してください。

最初のケースでは:

type chatbetweenusers struct {
    Time string `json:"time"`
    Text string `json:":"text"`
}

Text に関連付けられたタグの構文が間違っています。そのはず:

    Text string `json:"text"`

2 番目のケースでは:

type chatbetweenusers struct {
    Text string `json:":"text"`
    User1 string `json:":"user1"`
}

両方のタグに関連付けられた構文が間違っています。彼らはする必要があります:

    Text string `json:"text"`
    User1 string `json:"user1"`

プレイグラウンドの例を次に示します: https://play.golang.org/p/rirtTsTVWT

于 2015-01-03T18:38:35.967 に答える