ledisdb/store/writebatch.go

53 lines
843 B
Go
Raw Normal View History

2014-07-25 13:58:00 +04:00
package store
import (
"github.com/siddontang/ledisdb/store/driver"
2014-10-30 11:06:44 +03:00
"time"
2014-07-25 13:58:00 +04:00
)
2014-10-15 06:18:20 +04:00
type WriteBatch struct {
2014-10-30 11:06:44 +03:00
wb driver.IWriteBatch
st *Stat
2014-10-16 05:35:35 +04:00
2014-10-31 15:33:13 +03:00
putNum int64
deleteNum int64
db *DB
2014-10-15 06:18:20 +04:00
}
func (wb *WriteBatch) Put(key []byte, value []byte) {
2014-10-31 15:33:13 +03:00
wb.putNum++
2014-10-16 05:35:35 +04:00
wb.wb.Put(key, value)
2014-10-15 06:18:20 +04:00
}
func (wb *WriteBatch) Delete(key []byte) {
2014-10-31 15:33:13 +03:00
wb.deleteNum++
2014-10-16 05:35:35 +04:00
wb.wb.Delete(key)
2014-10-15 06:18:20 +04:00
}
func (wb *WriteBatch) Commit() error {
wb.st.BatchCommitNum.Add(1)
2014-10-31 15:33:13 +03:00
wb.st.PutNum.Add(wb.putNum)
wb.st.DeleteNum.Add(wb.deleteNum)
wb.putNum = 0
wb.deleteNum = 0
2014-10-30 11:06:44 +03:00
var err error
t := time.Now()
2014-10-16 05:35:35 +04:00
if wb.db == nil || !wb.db.needSyncCommit() {
2014-10-30 11:06:44 +03:00
err = wb.wb.Commit()
2014-10-16 05:35:35 +04:00
} else {
2014-10-30 11:06:44 +03:00
err = wb.wb.SyncCommit()
2014-10-16 05:35:35 +04:00
}
2014-10-30 11:06:44 +03:00
wb.st.BatchCommitTotalTime.Add(time.Now().Sub(t))
return err
2014-10-15 06:18:20 +04:00
}
func (wb *WriteBatch) Rollback() error {
2014-10-31 15:33:13 +03:00
wb.putNum = 0
wb.deleteNum = 0
2014-10-16 05:35:35 +04:00
return wb.wb.Rollback()
2014-07-25 13:58:00 +04:00
}