代码拉取完成,页面将自动刷新
package ormpool
import (
"fmt"
"sync"
"testing"
"time"
)
type Int struct {
Val int
}
func TestName(t *testing.T) {
var (
sql = "select count(*) as val from tptp"
tid = TenantId("111")
tpool, _ = NewTenantOrmPool(Mysql)
)
k, err := tpool.Register("mysql://root:root@tcp(127.0.0.1:3306)/test?charset=utf8mb4")
if err != nil {
panic(err)
}
err = tpool.Bound(tid, k)
if err != nil {
panic(err)
}
wg := sync.WaitGroup{}
wg.Add(1)
oldVal := 0
go func() {
defer wg.Done()
for i := 0; i < 20000; i++ {
db, err := tpool.GetDB(tid)
if err != nil {
panic(err)
}
v := &Int{}
cl := db.Raw(sql).Find(&v)
if cl.Error != nil {
panic(cl.Error)
}
if v.Val != oldVal {
oldVal = v.Val
fmt.Printf("%p\n%d\n", db, v.Val)
}
}
fmt.Println("======")
}()
time.Sleep(100 * time.Millisecond)
for i := 0; i < 150; i++ {
oldk := k
if i%2 == 0 {
k, err = tpool.Register("mysql://root:root@tcp(127.0.0.1:3306)/ry?charset=utf8mb4")
} else {
k, err = tpool.Register("mysql://root:root@tcp(127.0.0.1:3306)/test?charset=utf8mb4")
}
if err != nil {
panic(err)
}
err = tpool.Bound(tid, k)
if err != nil {
panic(err)
}
err = tpool.Release(oldk)
if err != nil {
panic(err)
}
time.Sleep(20 * time.Millisecond)
}
time.Sleep(10 * time.Second)
wg.Wait()
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。