本文整理汇总了Golang中github.com/ziutek/mymysql/mysql.Transaction.Rollback方法的典型用法代码示例。如果您正苦于以下问题:Golang Transaction.Rollback方法的具体用法?Golang Transaction.Rollback怎么用?Golang Transaction.Rollback使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/ziutek/mymysql/mysql.Transaction
的用法示例。
在下文中一共展示了Transaction.Rollback方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: Begin
// Begin begins a transaction and calls f to complete it .
// If f returns an error and IsNetErr(error) == true it reconnects and calls
// f up to MaxRetries times. If error is of type *mysql.Error it tries rollback
// the transaction.
func (c *Conn) Begin(f func(mysql.Transaction, ...interface{}) error, args ...interface{}) error {
err := c.connectIfNotConnected()
if err != nil {
return err
}
nn := 0
for {
var tr mysql.Transaction
if tr, err = c.Raw.Begin(); err == nil {
if err = f(tr, args...); err == nil {
return nil
}
}
if c.reconnectIfNetErr(&nn, &err); err != nil {
if _, ok := err.(*mysql.Error); ok && tr.IsValid() {
tr.Rollback()
}
return err
}
}
panic(nil)
}