mirror of
https://github.com/TeaOSLab/EdgeAPI.git
synced 2025-11-05 01:20:25 +08:00
减少在自增锁中生成的sql statements
This commit is contained in:
@@ -138,6 +138,7 @@ func (this *SysLockerDAO) Increase(tx *dbs.Tx, key string, defaultValue int64) (
|
|||||||
return result, err
|
return result, err
|
||||||
}
|
}
|
||||||
err := this.Query(tx).
|
err := this.Query(tx).
|
||||||
|
Reuse(false). // no need to prepare statement in every transaction
|
||||||
InsertOrUpdateQuickly(maps.Map{
|
InsertOrUpdateQuickly(maps.Map{
|
||||||
"key": key,
|
"key": key,
|
||||||
"version": defaultValue,
|
"version": defaultValue,
|
||||||
@@ -148,6 +149,7 @@ func (this *SysLockerDAO) Increase(tx *dbs.Tx, key string, defaultValue int64) (
|
|||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
return this.Query(tx).
|
return this.Query(tx).
|
||||||
|
Reuse(false). // no need to prepare statement in every transaction
|
||||||
Attr("key", key).
|
Attr("key", key).
|
||||||
Result("version").
|
Result("version").
|
||||||
FindInt64Col(0)
|
FindInt64Col(0)
|
||||||
|
|||||||
@@ -26,6 +26,21 @@ func TestSysLockerDAO_Lock(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestSysLocker_Increase_SQL(t *testing.T) {
|
||||||
|
var dao = NewSysLockerDAO()
|
||||||
|
value, err := dao.Read(nil, "hello")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
t.Log("before:", value)
|
||||||
|
v, err := dao.Increase(nil, "hello", 0)
|
||||||
|
if err != nil {
|
||||||
|
t.Log("err:", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
t.Log("after:", v)
|
||||||
|
}
|
||||||
|
|
||||||
func TestSysLocker_Increase(t *testing.T) {
|
func TestSysLocker_Increase(t *testing.T) {
|
||||||
dbs.NotifyReady()
|
dbs.NotifyReady()
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user