Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
画布下的乐园
oceanbase
提交
4a9e45d3
O
oceanbase
项目概览
画布下的乐园
/
oceanbase
与 Fork 源项目一致
Fork自
oceanbase / oceanbase
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
oceanbase
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
4a9e45d3
编写于
11月 02, 2022
作者:
O
obdev
提交者:
wangzelin.wzl
11月 02, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix memory leak caused by unclosed sql connection
上级
23963c5c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
9 addition
and
17 deletion
+9
-17
src/sql/engine/cmd/ob_variable_set_executor.cpp
src/sql/engine/cmd/ob_variable_set_executor.cpp
+9
-17
未找到文件。
src/sql/engine/cmd/ob_variable_set_executor.cpp
浏览文件 @
4a9e45d3
...
...
@@ -414,26 +414,18 @@ int ObVariableSetExecutor::execute_subquery_expr(ObExecContext &ctx,
LOG_WARN
(
"failed to get obj"
,
K
(
ret
),
K
(
idx
));
}
}
if
(
OB_FAIL
(
ret
))
{
}
else
if
(
OB_NOT_NULL
(
conn
)
&&
OB_NOT_NULL
(
sql_proxy
)
&&
OB_FAIL
(
sql_proxy
->
close
(
conn
,
true
)))
{
LOG_WARN
(
"failed to close connection"
,
K
(
ret
));
}
else
if
(
tmp_value
.
need_deep_copy
())
{
char
*
copy_data
=
NULL
;
int64_t
copy_size
=
tmp_value
.
get_deep_copy_size
();
int64_t
copy_pos
=
0
;
if
(
OB_ISNULL
(
copy_data
=
static_cast
<
char
*>
(
ctx
.
get_allocator
().
alloc
(
copy_size
))))
{
ret
=
OB_ALLOCATE_MEMORY_FAILED
;
LOG_WARN
(
"memory allocate failed"
,
K
(
ret
));
}
else
if
(
OB_FAIL
(
value_obj
.
deep_copy
(
tmp_value
,
copy_data
,
copy_size
,
copy_pos
)))
{
LOG_WARN
(
"obj deep copy failed"
,
K
(
ret
));
}
LOG_TRACE
(
"succeed to deep copy current value"
,
K
(
ret
));
}
else
{
value_obj
=
tmp_value
;
if
(
OB_SUCC
(
ret
)
&&
(
OB_FAIL
(
ob_write_obj
(
ctx
.
get_allocator
(),
tmp_value
,
value_obj
))))
{
LOG_WARN
(
"failed to write value"
,
K
(
ret
));
}
LOG_TRACE
(
"succ to calculate value by executing inner sql"
,
K
(
ret
),
K
(
value_obj
),
K
(
subquery_expr
));
}
if
(
OB_NOT_NULL
(
conn
)
&&
OB_NOT_NULL
(
sql_proxy
))
{
int
tmp_ret
=
sql_proxy
->
close
(
conn
,
true
);
if
(
OB_UNLIKELY
(
tmp_ret
!=
OB_SUCCESS
))
{
LOG_WARN
(
"failed to close sql connection"
,
K
(
tmp_ret
));
}
ret
=
ret
==
OB_SUCCESS
?
tmp_ret
:
ret
;
}
return
ret
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录