Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
二次元的罪恶王冠
beego
提交
a28d294a
B
beego
项目概览
二次元的罪恶王冠
/
beego
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
B
beego
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
a28d294a
编写于
6月 23, 2020
作者:
J
jianzhiyao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
upgrade acquire method return *sql.Stmt
上级
a5e8344a
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
14 deletion
+11
-14
orm/db_alias.go
orm/db_alias.go
+11
-14
未找到文件。
orm/db_alias.go
浏览文件 @
a28d294a
...
...
@@ -125,7 +125,6 @@ func (d *DB) getStmtDecorator(query string) (*stmtDecorator, error) {
c
,
ok
:=
d
.
stmtDecorators
.
Get
(
query
)
d
.
RUnlock
()
if
ok
{
c
.
(
*
stmtDecorator
)
.
acquire
()
return
c
.
(
*
stmtDecorator
),
nil
}
...
...
@@ -133,7 +132,6 @@ func (d *DB) getStmtDecorator(query string) (*stmtDecorator, error) {
c
,
ok
=
d
.
stmtDecorators
.
Get
(
query
)
if
ok
{
d
.
Unlock
()
c
.
(
*
stmtDecorator
)
.
acquire
()
return
c
.
(
*
stmtDecorator
),
nil
}
...
...
@@ -146,7 +144,6 @@ func (d *DB) getStmtDecorator(query string) (*stmtDecorator, error) {
d
.
stmtDecorators
.
Add
(
query
,
sd
)
d
.
Unlock
()
sd
.
acquire
()
return
sd
,
nil
}
...
...
@@ -163,7 +160,7 @@ func (d *DB) Exec(query string, args ...interface{}) (sql.Result, error) {
if
err
!=
nil
{
return
nil
,
err
}
stmt
:=
sd
.
getStmt
()
stmt
:=
sd
.
acquire
()
defer
sd
.
release
()
return
stmt
.
Exec
(
args
...
)
}
...
...
@@ -173,7 +170,7 @@ func (d *DB) ExecContext(ctx context.Context, query string, args ...interface{})
if
err
!=
nil
{
return
nil
,
err
}
stmt
:=
sd
.
getStmt
()
stmt
:=
sd
.
acquire
()
defer
sd
.
release
()
return
stmt
.
ExecContext
(
ctx
,
args
...
)
}
...
...
@@ -183,7 +180,7 @@ func (d *DB) Query(query string, args ...interface{}) (*sql.Rows, error) {
if
err
!=
nil
{
return
nil
,
err
}
stmt
:=
sd
.
getStmt
()
stmt
:=
sd
.
acquire
()
defer
sd
.
release
()
return
stmt
.
Query
(
args
...
)
}
...
...
@@ -193,7 +190,7 @@ func (d *DB) QueryContext(ctx context.Context, query string, args ...interface{}
if
err
!=
nil
{
return
nil
,
err
}
stmt
:=
sd
.
getStmt
()
stmt
:=
sd
.
acquire
()
defer
sd
.
release
()
return
stmt
.
QueryContext
(
ctx
,
args
...
)
}
...
...
@@ -203,7 +200,7 @@ func (d *DB) QueryRow(query string, args ...interface{}) *sql.Row {
if
err
!=
nil
{
panic
(
err
)
}
stmt
:=
sd
.
getStmt
()
stmt
:=
sd
.
acquire
()
defer
sd
.
release
()
return
stmt
.
QueryRow
(
args
...
)
...
...
@@ -214,7 +211,7 @@ func (d *DB) QueryRowContext(ctx context.Context, query string, args ...interfac
if
err
!=
nil
{
panic
(
err
)
}
stmt
:=
sd
.
getStmt
()
stmt
:=
sd
.
acquire
()
defer
sd
.
release
()
return
stmt
.
QueryRowContext
(
ctx
,
args
)
}
...
...
@@ -423,15 +420,14 @@ func GetDB(aliasNames ...string) (*sql.DB, error) {
type
stmtDecorator
struct
{
wg
sync
.
WaitGroup
lastUse
int64
stmt
*
sql
.
Stmt
}
func
(
s
*
stmtDecorator
)
getStmt
()
*
sql
.
Stmt
{
return
s
.
stmt
}
func
(
s
*
stmtDecorator
)
acquire
()
{
func
(
s
*
stmtDecorator
)
acquire
()
*
sql
.
Stmt
{
s
.
wg
.
Add
(
1
)
s
.
lastUse
=
time
.
Now
()
.
Unix
()
return
s
.
stmt
}
func
(
s
*
stmtDecorator
)
release
()
{
...
...
@@ -447,6 +443,7 @@ func (s *stmtDecorator) destroy() {
func
newStmtDecorator
(
sqlStmt
*
sql
.
Stmt
)
*
stmtDecorator
{
return
&
stmtDecorator
{
stmt
:
sqlStmt
,
lastUse
:
time
.
Now
()
.
Unix
(),
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录