Improve transactions
This commit is contained in:
parent
6075e4d1d7
commit
7556a77df0
13 changed files with 78 additions and 227 deletions
17
db/create.go
17
db/create.go
|
@ -24,17 +24,6 @@ import (
|
|||
|
||||
func executeCreateStatement(txn kvs.TX, ast *sql.CreateStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, w := range ast.What {
|
||||
|
||||
if what, ok := w.(*sql.Thing); ok {
|
||||
|
@ -61,10 +50,6 @@ func executeCreateStatement(txn kvs.TX, ast *sql.CreateStatement) (out []interfa
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
@ -76,7 +61,7 @@ func create(doc *item.Doc, ast *sql.CreateStatement) (out interface{}, err error
|
|||
}
|
||||
|
||||
if !doc.Allow("CREATE") {
|
||||
return nil, nil
|
||||
return
|
||||
}
|
||||
|
||||
if err = doc.StoreIndex(); err != nil {
|
||||
|
|
87
db/db.go
87
db/db.go
|
@ -111,13 +111,27 @@ func detail(e error) interface{} {
|
|||
}
|
||||
}
|
||||
|
||||
func writable(cur kvs.TX, tmp bool) (txn kvs.TX, err error, loc bool) {
|
||||
if cur == nil {
|
||||
cur, err = db.Txn(true)
|
||||
}
|
||||
return cur, err, tmp
|
||||
}
|
||||
|
||||
func readable(cur kvs.TX, tmp bool) (txn kvs.TX, err error, loc bool) {
|
||||
if cur == nil {
|
||||
cur, err = db.Txn(false)
|
||||
}
|
||||
return cur, err, tmp
|
||||
}
|
||||
|
||||
func execute(ctx *fibre.Context, ast *sql.Query, chn chan<- interface{}) {
|
||||
|
||||
var txn kvs.TX
|
||||
|
||||
defer func() {
|
||||
if txn != nil {
|
||||
txn.Rollback()
|
||||
txn.Cancel()
|
||||
}
|
||||
if r := recover(); r != nil {
|
||||
if err, ok := r.(error); ok {
|
||||
|
@ -130,15 +144,47 @@ func execute(ctx *fibre.Context, ast *sql.Query, chn chan<- interface{}) {
|
|||
|
||||
for _, s := range ast.Statements {
|
||||
|
||||
var res []interface{}
|
||||
var loc bool
|
||||
var err error
|
||||
var res []interface{}
|
||||
|
||||
now := time.Now()
|
||||
|
||||
switch stm := s.(type) {
|
||||
switch s.(type) {
|
||||
|
||||
case *sql.UseStatement:
|
||||
continue
|
||||
case *sql.BeginStatement:
|
||||
break
|
||||
case *sql.CancelStatement:
|
||||
break
|
||||
case *sql.CommitStatement:
|
||||
break
|
||||
case *sql.InfoStatement:
|
||||
txn, err, loc = readable(txn, txn == nil)
|
||||
default:
|
||||
txn, err, loc = writable(txn, txn == nil)
|
||||
}
|
||||
|
||||
if err != nil {
|
||||
chn <- err
|
||||
}
|
||||
|
||||
switch stm := s.(type) {
|
||||
|
||||
case *sql.CommitStatement:
|
||||
txn.Commit()
|
||||
txn = nil
|
||||
continue
|
||||
|
||||
case *sql.CancelStatement:
|
||||
txn.Cancel()
|
||||
txn = nil
|
||||
continue
|
||||
|
||||
case *sql.BeginStatement:
|
||||
txn, err, loc = writable(txn, false)
|
||||
continue
|
||||
|
||||
case *sql.InfoStatement:
|
||||
res, err = executeInfoStatement(txn, stm)
|
||||
|
@ -176,36 +222,21 @@ func execute(ctx *fibre.Context, ast *sql.Query, chn chan<- interface{}) {
|
|||
case *sql.RemoveIndexStatement:
|
||||
res, err = executeRemoveIndexStatement(txn, stm)
|
||||
|
||||
case *sql.BeginStatement:
|
||||
if txn != nil {
|
||||
chn <- fibre.NewHTTPError(400, "Transaction already running")
|
||||
return
|
||||
} else if txn, err = db.Txn(true); err != nil {
|
||||
chn <- err
|
||||
return
|
||||
}
|
||||
|
||||
case *sql.CommitStatement:
|
||||
if txn != nil {
|
||||
txn.Commit()
|
||||
txn = nil
|
||||
continue
|
||||
}
|
||||
|
||||
case *sql.CancelStatement:
|
||||
if txn != nil {
|
||||
txn.Rollback()
|
||||
txn = nil
|
||||
continue
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
if err != nil && txn != nil {
|
||||
txn.Rollback()
|
||||
if err != nil {
|
||||
chn <- err
|
||||
}
|
||||
|
||||
if loc {
|
||||
if err != nil {
|
||||
txn.Cancel()
|
||||
} else {
|
||||
txn.Commit()
|
||||
}
|
||||
txn = nil
|
||||
}
|
||||
|
||||
chn <- &Response{
|
||||
Time: time.Since(now).String(),
|
||||
Status: status(err),
|
||||
|
|
60
db/define.go
60
db/define.go
|
@ -24,17 +24,6 @@ import (
|
|||
|
||||
func executeDefineTableStatement(txn kvs.TX, ast *sql.DefineTableStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, TB := range ast.What {
|
||||
|
||||
// Set the namespace definition
|
||||
|
@ -57,27 +46,12 @@ func executeDefineTableStatement(txn kvs.TX, ast *sql.DefineTableStatement) (out
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
||||
func executeDefineRulesStatement(txn kvs.TX, ast *sql.DefineRulesStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, TB := range ast.What {
|
||||
|
||||
for _, RU := range ast.When {
|
||||
|
@ -110,27 +84,12 @@ func executeDefineRulesStatement(txn kvs.TX, ast *sql.DefineRulesStatement) (out
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
||||
func executeDefineFieldStatement(txn kvs.TX, ast *sql.DefineFieldStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, TB := range ast.What {
|
||||
|
||||
// Set the namespace definition
|
||||
|
@ -159,27 +118,12 @@ func executeDefineFieldStatement(txn kvs.TX, ast *sql.DefineFieldStatement) (out
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
||||
func executeDefineIndexStatement(txn kvs.TX, ast *sql.DefineIndexStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, TB := range ast.What {
|
||||
|
||||
// Set the namespace definition
|
||||
|
@ -226,10 +170,6 @@ func executeDefineIndexStatement(txn kvs.TX, ast *sql.DefineIndexStatement) (out
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
|
15
db/delete.go
15
db/delete.go
|
@ -23,17 +23,6 @@ import (
|
|||
|
||||
func executeDeleteStatement(txn kvs.TX, ast *sql.DeleteStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, w := range ast.What {
|
||||
|
||||
if what, ok := w.(*sql.Thing); ok {
|
||||
|
@ -63,10 +52,6 @@ func executeDeleteStatement(txn kvs.TX, ast *sql.DeleteStatement) (out []interfa
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
|
|
@ -25,14 +25,6 @@ import (
|
|||
|
||||
func executeInfoStatement(txn kvs.TX, ast *sql.InfoStatement) (out []interface{}, err error) {
|
||||
|
||||
if txn == nil {
|
||||
txn, err = db.Txn(false)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
if ast.What == "" {
|
||||
|
||||
res := data.New()
|
||||
|
|
15
db/modify.go
15
db/modify.go
|
@ -23,17 +23,6 @@ import (
|
|||
|
||||
func executeModifyStatement(txn kvs.TX, ast *sql.ModifyStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, w := range ast.What {
|
||||
|
||||
if what, ok := w.(*sql.Thing); ok {
|
||||
|
@ -63,10 +52,6 @@ func executeModifyStatement(txn kvs.TX, ast *sql.ModifyStatement) (out []interfa
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
|
60
db/remove.go
60
db/remove.go
|
@ -22,17 +22,6 @@ import (
|
|||
|
||||
func executeRemoveTableStatement(txn kvs.TX, ast *sql.RemoveTableStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, TB := range ast.What {
|
||||
|
||||
// Remove the table config
|
||||
|
@ -67,27 +56,12 @@ func executeRemoveTableStatement(txn kvs.TX, ast *sql.RemoveTableStatement) (out
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
||||
func executeRemoveRulesStatement(txn kvs.TX, ast *sql.RemoveRulesStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, TB := range ast.What {
|
||||
|
||||
for _, RU := range ast.When {
|
||||
|
@ -102,27 +76,12 @@ func executeRemoveRulesStatement(txn kvs.TX, ast *sql.RemoveRulesStatement) (out
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
||||
func executeRemoveFieldStatement(txn kvs.TX, ast *sql.RemoveFieldStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, TB := range ast.What {
|
||||
|
||||
// Remove the field config
|
||||
|
@ -133,27 +92,12 @@ func executeRemoveFieldStatement(txn kvs.TX, ast *sql.RemoveFieldStatement) (out
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
||||
func executeRemoveIndexStatement(txn kvs.TX, ast *sql.RemoveIndexStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, TB := range ast.What {
|
||||
|
||||
// Remove the index config
|
||||
|
@ -170,10 +114,6 @@ func executeRemoveIndexStatement(txn kvs.TX, ast *sql.RemoveIndexStatement) (out
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
|
10
db/select.go
10
db/select.go
|
@ -23,14 +23,6 @@ import (
|
|||
|
||||
func executeSelectStatement(txn kvs.TX, ast *sql.SelectStatement) (out []interface{}, err error) {
|
||||
|
||||
if txn == nil {
|
||||
txn, err = db.Txn(false)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Close()
|
||||
}
|
||||
|
||||
for _, w := range ast.What {
|
||||
|
||||
if what, ok := w.(*sql.Thing); ok {
|
||||
|
@ -71,7 +63,7 @@ func detect(doc *item.Doc, ast *sql.SelectStatement) (out interface{}, err error
|
|||
}
|
||||
|
||||
if !doc.Allow("SELECT") {
|
||||
return nil, nil
|
||||
return
|
||||
}
|
||||
|
||||
out = doc.Blaze(ast)
|
||||
|
|
15
db/update.go
15
db/update.go
|
@ -23,17 +23,6 @@ import (
|
|||
|
||||
func executeUpdateStatement(txn kvs.TX, ast *sql.UpdateStatement) (out []interface{}, err error) {
|
||||
|
||||
var local bool
|
||||
|
||||
if txn == nil {
|
||||
local = true
|
||||
txn, err = db.Txn(true)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer txn.Rollback()
|
||||
}
|
||||
|
||||
for _, w := range ast.What {
|
||||
|
||||
if what, ok := w.(*sql.Thing); ok {
|
||||
|
@ -63,10 +52,6 @@ func executeUpdateStatement(txn kvs.TX, ast *sql.UpdateStatement) (out []interfa
|
|||
|
||||
}
|
||||
|
||||
if local {
|
||||
txn.Commit()
|
||||
}
|
||||
|
||||
return
|
||||
|
||||
}
|
||||
|
|
|
@ -333,8 +333,15 @@ func (tx *TX) Close() (err error) {
|
|||
return tx.Rollback()
|
||||
}
|
||||
|
||||
func (tx *TX) Cancel() (err error) {
|
||||
return tx.Rollback()
|
||||
}
|
||||
|
||||
func (tx *TX) Commit() (err error) {
|
||||
return tx.tx.Commit()
|
||||
if tx.tx.Writable() {
|
||||
return tx.tx.Commit()
|
||||
}
|
||||
return tx.tx.Rollback()
|
||||
}
|
||||
|
||||
func (tx *TX) Rollback() (err error) {
|
||||
|
|
|
@ -314,6 +314,10 @@ func (tx *TX) Close() (err error) {
|
|||
return tx.Rollback()
|
||||
}
|
||||
|
||||
func (tx *TX) Cancel() (err error) {
|
||||
return tx.Rollback()
|
||||
}
|
||||
|
||||
func (tx *TX) Commit() (err error) {
|
||||
return tx.tx.Commit()
|
||||
}
|
||||
|
|
|
@ -314,6 +314,10 @@ func (tx *TX) Close() (err error) {
|
|||
return tx.Rollback()
|
||||
}
|
||||
|
||||
func (tx *TX) Cancel() (err error) {
|
||||
return tx.Rollback()
|
||||
}
|
||||
|
||||
func (tx *TX) Commit() (err error) {
|
||||
return tx.tx.Commit()
|
||||
}
|
||||
|
|
|
@ -29,6 +29,7 @@ type TX interface {
|
|||
PDel([]byte) error
|
||||
RDel([]byte, []byte, uint64) error
|
||||
Close() error
|
||||
Cancel() error
|
||||
Commit() error
|
||||
Rollback() error
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue