当我试图从我的数据库中获取JSON数据时,我得到了以下内容:
{“时间”:“13:42:21 11.12.14”、":":"Привет"}
{“时间”:“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组合其他数据时会发生什么?我试过了所有可能的方法,但这不能正常工作。
发布于 2015-01-03 18:38:35
考虑一下定义结构的方式。
在第一种情况下:
type chatbetweenusers struct {
Time string `json:"time"`
Text string `json:":"text"`
}与文本关联的标记的语法是错误的。它应该是:
Text string `json:"text"`在第二种情况下:
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
https://stackoverflow.com/questions/27756856
复制相似问题