struct Time 属性 不从 Go sqlx 库加载
struct Time property doesn't load from Go sqlx library
我有一个 属性 时间的结构:
type Basket struct {
...
Created_at time.Time `db:"created_at"`
}
时间保存为:
basket.Created_at = time.Now().UTC()
如果我使用 Insert sql 语句保存它,它会在 SQLite3 中很好地节省时间,但是当我 select 使用
所需的记录时
ret_basket := Basket{}
err := database.DB.Get(&ret_basket, "SELECT id, ..., created_at FROM baskets WHERE user_id = ?", some_user_id)
它 returns 除了时间 属性 ret_basket.Created_at
和 0001-01-01 00:00:00 +0000 UTC
之外其他属性的记录正确加载
有什么建议吗?
没有官方的 Sqlite 包所以我假设你正在使用 https://github.com/mattn/go-sqlite3 可能你的问题是数据库中错误的 created_at
字段声明的结果应该是 DATETIME
因为下一个代码在我的机器上运行完美(我删除了所有错误检查):
package main
import (
"github.com/jmoiron/sqlx"
_ "github.com/mattn/go-sqlite3"
"log"
"time"
)
type Post struct {
Id int64 `db:"post_id"`
Created time.Time `db:"created"`
}
func main() {
db, _ := sqlx.Connect("sqlite3", "post_db.db")
db.MustExec("DROP TABLE IF EXISTS posts; CREATE TABLE posts (post_id INT, created DATETIME);")
p1 := Post{Id: 1, Created: time.Now().UTC()}
p2 := Post{}
tx := db.MustBegin()
tx.NamedExec("INSERT INTO posts (post_id, created) VALUES (:post_id, :created)", &p1)
tx.Commit()
db.Get(&p2, "SELECT post_id, created FROM posts WHERE post_id = ", p1.Id)
log.Println(p2.Created.Format("2006-01-02"))
}
我有一个 属性 时间的结构:
type Basket struct {
...
Created_at time.Time `db:"created_at"`
}
时间保存为:
basket.Created_at = time.Now().UTC()
如果我使用 Insert sql 语句保存它,它会在 SQLite3 中很好地节省时间,但是当我 select 使用
所需的记录时ret_basket := Basket{}
err := database.DB.Get(&ret_basket, "SELECT id, ..., created_at FROM baskets WHERE user_id = ?", some_user_id)
它 returns 除了时间 属性 ret_basket.Created_at
和 0001-01-01 00:00:00 +0000 UTC
有什么建议吗?
没有官方的 Sqlite 包所以我假设你正在使用 https://github.com/mattn/go-sqlite3 可能你的问题是数据库中错误的 created_at
字段声明的结果应该是 DATETIME
因为下一个代码在我的机器上运行完美(我删除了所有错误检查):
package main
import (
"github.com/jmoiron/sqlx"
_ "github.com/mattn/go-sqlite3"
"log"
"time"
)
type Post struct {
Id int64 `db:"post_id"`
Created time.Time `db:"created"`
}
func main() {
db, _ := sqlx.Connect("sqlite3", "post_db.db")
db.MustExec("DROP TABLE IF EXISTS posts; CREATE TABLE posts (post_id INT, created DATETIME);")
p1 := Post{Id: 1, Created: time.Now().UTC()}
p2 := Post{}
tx := db.MustBegin()
tx.NamedExec("INSERT INTO posts (post_id, created) VALUES (:post_id, :created)", &p1)
tx.Commit()
db.Get(&p2, "SELECT post_id, created FROM posts WHERE post_id = ", p1.Id)
log.Println(p2.Created.Format("2006-01-02"))
}