如何确保按顺序解决所有写入事务功能?另外,为什么else函数没有执行?

时间:2019-01-13 23:41:31

标签: json database go boltdb

我正在尝试创建一个名为“ ledger.db”的非常简单的Bolt数据库,其中包含一个名为“ Users”的存储桶,其中包含用户名作为键,Balances作为允许用户将其余额转移到一个的值另一个。我正在使用Bolter在命令行中查看数据库

存在两个问题,此传递函数中都包含的两个问题都位于传递函数中。

第一个:在传递函数内部是if / else。如果条件为真,它将按预期执行。如果为假,则什么也不会发生。没有语法错误,程序运行好像没有什么错误,只是不执行else语句。

第二个:即使条件为true,执行条件时也不会同时更新数据库中的相应余额值。它会更新接收者的余额,但对发送者却没有作用。数学运算已完成,值已编组为JSON兼容格式。

问题在于发件人余额未在数据库中更新。

第二个“成功!”中的所有内容以后的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

1 个答案:

答案 0 :(得分:2)

您无条件返回:

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!")

您没有返回并检查错误。

json.Unmarshal(uBuck.Get([]byte(from.username)), &fbalance)
json.Unmarshal(uBuck.Get([]byte(to.username)), &tbalance)

t.transfer(b, 40000)

以此类推。


按语句调试代码语句。