Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
b9ebb7d3
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
b9ebb7d3
编写于
4月 04, 2020
作者:
H
hjxilinx
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[TD-98]
上级
aa9abd4d
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
6 addition
and
61 deletion
+6
-61
src/client/src/tscParseInsert.c
src/client/src/tscParseInsert.c
+6
-56
src/client/src/tscSql.c
src/client/src/tscSql.c
+0
-5
未找到文件。
src/client/src/tscParseInsert.c
浏览文件 @
b9ebb7d3
...
@@ -1291,7 +1291,7 @@ int tsParseInsertSql(SSqlObj *pSql) {
...
@@ -1291,7 +1291,7 @@ int tsParseInsertSql(SSqlObj *pSql) {
return
doParseInsertSql
(
pSql
,
pSql
->
sqlstr
+
index
);
return
doParseInsertSql
(
pSql
,
pSql
->
sqlstr
+
index
);
}
}
int
tsParseSql
(
SSqlObj
*
pSql
,
bool
initalParse
)
{
int
tsParseSql
(
SSqlObj
*
pSql
,
bool
init
i
alParse
)
{
int32_t
ret
=
TSDB_CODE_SUCCESS
;
int32_t
ret
=
TSDB_CODE_SUCCESS
;
tscTrace
(
"continue parse sql: %s"
,
pSql
->
asyncTblPos
);
tscTrace
(
"continue parse sql: %s"
,
pSql
->
asyncTblPos
);
...
@@ -1301,10 +1301,11 @@ int tsParseSql(SSqlObj *pSql, bool initalParse) {
...
@@ -1301,10 +1301,11 @@ int tsParseSql(SSqlObj *pSql, bool initalParse) {
* Set the fp before parse the sql string, in case of getmetermeta failed, in which
* Set the fp before parse the sql string, in case of getmetermeta failed, in which
* the error handle callback function can rightfully restore the user defined function (fp)
* the error handle callback function can rightfully restore the user defined function (fp)
*/
*/
if
(
pSql
->
fp
!=
NULL
&&
init
alParse
)
{
if
(
initi
alParse
)
{
pSql
->
fetchFp
=
pSql
->
fp
;
tscFreeSqlCmdData
(
&
pSql
->
cmd
)
;
// replace user defined callback function with multi-insert proxy function
// replace user defined callback function with multi-insert proxy function
pSql
->
fetchFp
=
pSql
->
fp
;
pSql
->
fp
=
(
void
(
*
)())
tscHandleMultivnodeInsert
;
pSql
->
fp
=
(
void
(
*
)())
tscHandleMultivnodeInsert
;
}
}
...
@@ -1315,7 +1316,7 @@ int tsParseSql(SSqlObj *pSql, bool initalParse) {
...
@@ -1315,7 +1316,7 @@ int tsParseSql(SSqlObj *pSql, bool initalParse) {
return
ret
;
return
ret
;
}
}
if
(
initalParse
)
{
if
(
init
i
alParse
)
{
tscFreeSqlCmdData
(
&
pSql
->
cmd
);
tscFreeSqlCmdData
(
&
pSql
->
cmd
);
}
}
...
@@ -1449,57 +1450,6 @@ static int tscInsertDataFromFile(SSqlObj *pSql, FILE *fp, char *tmpTokenBuf) {
...
@@ -1449,57 +1450,6 @@ static int tscInsertDataFromFile(SSqlObj *pSql, FILE *fp, char *tmpTokenBuf) {
return
numOfRows
;
return
numOfRows
;
}
}
/* multi-vnodes insertion in sync query model
*
* modify history
* 2019.05.10 lihui
* Remove the code for importing records from files
*/
void
tscProcessMultiVnodesInsert
(
SSqlObj
*
pSql
)
{
SSqlCmd
*
pCmd
=
&
pSql
->
cmd
;
// not insert/import, return directly
if
(
pCmd
->
command
!=
TSDB_SQL_INSERT
)
{
return
;
}
// SSqlCmd may have been released
if
(
pCmd
->
pDataBlocks
==
NULL
)
{
return
;
}
STableDataBlocks
*
pDataBlock
=
NULL
;
STableMetaInfo
*
pTableMetaInfo
=
tscGetTableMetaInfoFromCmd
(
pCmd
,
pCmd
->
clauseIndex
,
0
);
assert
(
pCmd
->
numOfClause
==
1
);
int32_t
code
=
TSDB_CODE_SUCCESS
;
/* the first block has been sent to server in processSQL function */
assert
(
pTableMetaInfo
->
vnodeIndex
>=
1
&&
pCmd
->
pDataBlocks
!=
NULL
);
if
(
pTableMetaInfo
->
vnodeIndex
<
pCmd
->
pDataBlocks
->
nSize
)
{
SDataBlockList
*
pDataBlocks
=
pCmd
->
pDataBlocks
;
for
(
int32_t
i
=
pTableMetaInfo
->
vnodeIndex
;
i
<
pDataBlocks
->
nSize
;
++
i
)
{
pDataBlock
=
pDataBlocks
->
pData
[
i
];
if
(
pDataBlock
==
NULL
)
{
continue
;
}
if
((
code
=
tscCopyDataBlockToPayload
(
pSql
,
pDataBlock
))
!=
TSDB_CODE_SUCCESS
)
{
tscTrace
(
"%p build submit data block failed, vnodeIdx:%d, total:%d"
,
pSql
,
pTableMetaInfo
->
vnodeIndex
,
pDataBlocks
->
nSize
);
continue
;
}
tscProcessSql
(
pSql
);
}
}
// all data have been submit to vnode, release data blocks
pCmd
->
pDataBlocks
=
tscDestroyBlockArrayList
(
pCmd
->
pDataBlocks
);
}
// multi-vnodes insertion in sync query model
// multi-vnodes insertion in sync query model
void
tscProcessMultiVnodesInsertFromFile
(
SSqlObj
*
pSql
)
{
void
tscProcessMultiVnodesInsertFromFile
(
SSqlObj
*
pSql
)
{
SSqlCmd
*
pCmd
=
&
pSql
->
cmd
;
SSqlCmd
*
pCmd
=
&
pSql
->
cmd
;
...
...
src/client/src/tscSql.c
浏览文件 @
b9ebb7d3
...
@@ -297,11 +297,6 @@ int taos_query(TAOS *taos, const char *sqlstr) {
...
@@ -297,11 +297,6 @@ int taos_query(TAOS *taos, const char *sqlstr) {
// wait for the callback function to post the semaphore
// wait for the callback function to post the semaphore
sem_wait
(
&
pSql
->
rspSem
);
sem_wait
(
&
pSql
->
rspSem
);
if
(
pSql
->
res
.
code
!=
TSDB_CODE_SUCCESS
)
{
tscFreeSqlCmdData
(
&
pSql
->
cmd
);
}
return
pSql
->
res
.
code
;
return
pSql
->
res
.
code
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录