我怎样才能确保我所有的写交易功能都按顺序得到解决?另外,为什么else函数没有执行?
How can I ensure that all of my write transaction functions get resolved in order? Also, why is the else function not executing?
我正在尝试创建一个名为 "ledger.db" 的非常简单的 Bolt 数据库,其中包含一个名为 "Users" 的 Bucket,其中包含用户名作为键和余额作为允许用户转移的值他们之间的平衡。我正在使用 Bolter 在命令行中查看数据库
有两个问题,都包含在这个传递函数中,问题在于传递函数。
第一:传递函数内部是一个if/else。如果条件为真,它会按预期执行。如果它是假的,什么也不会发生。没有语法错误,程序运行起来好像没有任何问题,它只是不执行 else 语句。
其二:即使条件为真,执行时也不会同时更新数据库中各自的余额值。它会更新接收方的余额,但不会为发送方做同样的事情。数学运算已完成,值被编组为 JSON 兼容格式。
问题是发件人余额没有在数据库中更新。
从第二个 "Success!" fmt.Println() 函数开始的所有内容都不会被处理
我试过将 "db.Update()" 更改为 "db.Batch()"。我试过更改 Put() 函数的顺序。我试过搞乱 goroutines 和 defer,但我不知道如何使用它们,因为我对 golang 很陌生。
func (from *User) transfer(to User, amount int) error{
var fbalance int = 0
var tbalance int = 0
db, err := bolt.Open("ledger.db", 0600, nil)
if err != nil {
log.Fatal(err)
}
defer db.Close()
return db.Update(func(tx *bolt.Tx) error {
uBuck := tx.Bucket([]byte("Users"))
json.Unmarshal(uBuck.Get([]byte(from.username)), &fbalance)
json.Unmarshal(uBuck.Get([]byte(to.username)), &tbalance)
if (amount <= fbalance) {
fbalance = fbalance - amount
encoded, err := json.Marshal(fbalance)
if err != nil {
return err
}
tbalance = tbalance + amount
encoded2, err := json.Marshal(tbalance)
if err != nil {
return err
}
fmt.Println("Success!")
c := uBuck
err = c.Put([]byte(to.username), encoded2)
return err
fmt.Println("Success!")
err = c.Put([]byte(from.username), encoded)
return err
fmt.Println("Success!")
} else {
return fmt.Errorf("Not enough in balance!", amount)
}
return nil
})
return nil
}
func main() {
/*
db, err := bolt.Open("ledger.db", 0600, nil)
if err != nil {
log.Fatal(err)
}
defer db.Close()
*/
var b User = User{"Big", "jig", 50000, 0}
var t User = User{"Trig", "pig", 40000, 0}
// These two functions add each User to the database, they aren't
// the problem
b.createUser()
t.createUser()
/*
db.View(func(tx *bolt.Tx) error {
c := tx.Bucket([]byte("Users"))
get := c.Get([]byte(b.username))
fmt.Printf("The return value %v",get)
return nil
})
*/
t.transfer(b, 40000)
}
我希望数据库从 Big:50000 Trig:40000
的起始值开始显示 Big:90000 Trig:0
相反,程序输出 Big:90000 Trig:40000
你return无条件:
c := uBuck
err = c.Put([]byte(to.username), encoded2)
return err
fmt.Println("Success!")
err = c.Put([]byte(from.username), encoded)
return err
fmt.Println("Success!")
您没有return检查错误。
json.Unmarshal(uBuck.Get([]byte(from.username)), &fbalance)
json.Unmarshal(uBuck.Get([]byte(to.username)), &tbalance)
t.transfer(b, 40000)
以此类推
逐条调试代码。
我正在尝试创建一个名为 "ledger.db" 的非常简单的 Bolt 数据库,其中包含一个名为 "Users" 的 Bucket,其中包含用户名作为键和余额作为允许用户转移的值他们之间的平衡。我正在使用 Bolter 在命令行中查看数据库
有两个问题,都包含在这个传递函数中,问题在于传递函数。
第一:传递函数内部是一个if/else。如果条件为真,它会按预期执行。如果它是假的,什么也不会发生。没有语法错误,程序运行起来好像没有任何问题,它只是不执行 else 语句。
其二:即使条件为真,执行时也不会同时更新数据库中各自的余额值。它会更新接收方的余额,但不会为发送方做同样的事情。数学运算已完成,值被编组为 JSON 兼容格式。
问题是发件人余额没有在数据库中更新。
从第二个 "Success!" fmt.Println() 函数开始的所有内容都不会被处理
我试过将 "db.Update()" 更改为 "db.Batch()"。我试过更改 Put() 函数的顺序。我试过搞乱 goroutines 和 defer,但我不知道如何使用它们,因为我对 golang 很陌生。
func (from *User) transfer(to User, amount int) error{
var fbalance int = 0
var tbalance int = 0
db, err := bolt.Open("ledger.db", 0600, nil)
if err != nil {
log.Fatal(err)
}
defer db.Close()
return db.Update(func(tx *bolt.Tx) error {
uBuck := tx.Bucket([]byte("Users"))
json.Unmarshal(uBuck.Get([]byte(from.username)), &fbalance)
json.Unmarshal(uBuck.Get([]byte(to.username)), &tbalance)
if (amount <= fbalance) {
fbalance = fbalance - amount
encoded, err := json.Marshal(fbalance)
if err != nil {
return err
}
tbalance = tbalance + amount
encoded2, err := json.Marshal(tbalance)
if err != nil {
return err
}
fmt.Println("Success!")
c := uBuck
err = c.Put([]byte(to.username), encoded2)
return err
fmt.Println("Success!")
err = c.Put([]byte(from.username), encoded)
return err
fmt.Println("Success!")
} else {
return fmt.Errorf("Not enough in balance!", amount)
}
return nil
})
return nil
}
func main() {
/*
db, err := bolt.Open("ledger.db", 0600, nil)
if err != nil {
log.Fatal(err)
}
defer db.Close()
*/
var b User = User{"Big", "jig", 50000, 0}
var t User = User{"Trig", "pig", 40000, 0}
// These two functions add each User to the database, they aren't
// the problem
b.createUser()
t.createUser()
/*
db.View(func(tx *bolt.Tx) error {
c := tx.Bucket([]byte("Users"))
get := c.Get([]byte(b.username))
fmt.Printf("The return value %v",get)
return nil
})
*/
t.transfer(b, 40000)
}
我希望数据库从 Big:50000 Trig:40000
的起始值开始显示 Big:90000 Trig:0相反,程序输出 Big:90000 Trig:40000
你return无条件:
c := uBuck
err = c.Put([]byte(to.username), encoded2)
return err
fmt.Println("Success!")
err = c.Put([]byte(from.username), encoded)
return err
fmt.Println("Success!")
您没有return检查错误。
json.Unmarshal(uBuck.Get([]byte(from.username)), &fbalance)
json.Unmarshal(uBuck.Get([]byte(to.username)), &tbalance)
t.transfer(b, 40000)
以此类推
逐条调试代码。