Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
0631d1f0
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
0631d1f0
编写于
12月 11, 2021
作者:
D
dapan1121
提交者:
GitHub
12月 11, 2021
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #8997 from taosdata/hotfix/TD-11899
[td-11899]STMT use now as timestamp cause "Timestamp out of range" error
上级
2c642daf
749ed71a
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
110 addition
and
0 deletion
+110
-0
src/client/src/tscPrepare.c
src/client/src/tscPrepare.c
+40
-0
tests/script/api/batchprepare.c
tests/script/api/batchprepare.c
+70
-0
未找到文件。
src/client/src/tscPrepare.c
浏览文件 @
0631d1f0
...
@@ -1533,6 +1533,41 @@ int stmtGenInsertStatement(SSqlObj* pSql, STscStmt* pStmt, const char* name, TAO
...
@@ -1533,6 +1533,41 @@ int stmtGenInsertStatement(SSqlObj* pSql, STscStmt* pStmt, const char* name, TAO
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
int32_t
stmtValidateValuesFields
(
SSqlCmd
*
pCmd
,
char
*
sql
)
{
int32_t
loopCont
=
1
,
index0
=
0
,
values
=
0
;
SStrToken
sToken
;
while
(
loopCont
)
{
sToken
=
tStrGetToken
(
sql
,
&
index0
,
false
);
if
(
sToken
.
n
<=
0
)
{
return
TSDB_CODE_SUCCESS
;
}
switch
(
sToken
.
type
)
{
case
TK_RP
:
if
(
values
)
{
return
TSDB_CODE_SUCCESS
;
}
break
;
case
TK_VALUES
:
values
=
1
;
break
;
case
TK_QUESTION
:
case
TK_LP
:
break
;
default:
if
(
values
)
{
tscError
(
"only ? allowed in values"
);
return
tscInvalidOperationMsg
(
pCmd
->
payload
,
"only ? allowed in values"
,
NULL
);
}
break
;
}
}
return
TSDB_CODE_SUCCESS
;
}
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
// interface functions
// interface functions
...
@@ -1637,6 +1672,11 @@ int taos_stmt_prepare(TAOS_STMT* stmt, const char* sql, unsigned long length) {
...
@@ -1637,6 +1672,11 @@ int taos_stmt_prepare(TAOS_STMT* stmt, const char* sql, unsigned long length) {
STMT_RET
(
ret
);
STMT_RET
(
ret
);
}
}
ret
=
stmtValidateValuesFields
(
&
pSql
->
cmd
,
pSql
->
sqlstr
);
if
(
ret
!=
TSDB_CODE_SUCCESS
)
{
STMT_RET
(
ret
);
}
if
(
pStmt
->
multiTbInsert
)
{
if
(
pStmt
->
multiTbInsert
)
{
STMT_RET
(
TSDB_CODE_SUCCESS
);
STMT_RET
(
TSDB_CODE_SUCCESS
);
}
}
...
...
tests/script/api/batchprepare.c
浏览文件 @
0631d1f0
...
@@ -2722,6 +2722,38 @@ int stmt_funcb_autoctb_e5(TAOS_STMT *stmt) {
...
@@ -2722,6 +2722,38 @@ int stmt_funcb_autoctb_e5(TAOS_STMT *stmt) {
}
}
int
stmt_funcb_autoctb_e6
(
TAOS_STMT
*
stmt
)
{
char
*
sql
=
"insert into ? using stb1 tags(?,?,?,?,?,?,?,?,?) values(now,?,?,?,?,?,?,?,?,?)"
;
int
code
=
taos_stmt_prepare
(
stmt
,
sql
,
0
);
if
(
code
!=
0
){
printf
(
"case success:failed to execute taos_stmt_prepare. code:%s
\n
"
,
taos_stmt_errstr
(
stmt
));
}
return
0
;
}
int
stmt_funcb_autoctb_e7
(
TAOS_STMT
*
stmt
)
{
char
*
sql
=
"insert into ? using stb1 tags(?,?,?,?,?,?,?,?,?) values(?,true,?,?,?,?,?,?,?,?)"
;
int
code
=
taos_stmt_prepare
(
stmt
,
sql
,
0
);
if
(
code
!=
0
){
printf
(
"case success:failed to execute taos_stmt_prepare. code:%s
\n
"
,
taos_stmt_errstr
(
stmt
));
}
return
0
;
}
int
stmt_funcb_autoctb_e8
(
TAOS_STMT
*
stmt
)
{
char
*
sql
=
"insert into ? using stb1 tags(?,?,?,?,?,?,?,?,?) values(?,?,1,?,?,?,?,?,?,?)"
;
int
code
=
taos_stmt_prepare
(
stmt
,
sql
,
0
);
if
(
code
!=
0
){
printf
(
"case success:failed to execute taos_stmt_prepare. code:%s
\n
"
,
taos_stmt_errstr
(
stmt
));
}
return
0
;
}
//300 tables 60 records
//300 tables 60 records
int
stmt_funcb1
(
TAOS_STMT
*
stmt
)
{
int
stmt_funcb1
(
TAOS_STMT
*
stmt
)
{
...
@@ -4857,6 +4889,44 @@ void* runcase(void *par) {
...
@@ -4857,6 +4889,44 @@ void* runcase(void *par) {
#endif
#endif
#if 1
prepare
(
taos
,
1
,
0
);
stmt
=
taos_stmt_init
(
taos
);
printf
(
"e6 start
\n
"
);
stmt_funcb_autoctb_e6
(
stmt
);
printf
(
"e6 end
\n
"
);
taos_stmt_close
(
stmt
);
#endif
#if 1
prepare
(
taos
,
1
,
0
);
stmt
=
taos_stmt_init
(
taos
);
printf
(
"e7 start
\n
"
);
stmt_funcb_autoctb_e7
(
stmt
);
printf
(
"e7 end
\n
"
);
taos_stmt_close
(
stmt
);
#endif
#if 1
prepare
(
taos
,
1
,
0
);
stmt
=
taos_stmt_init
(
taos
);
printf
(
"e8 start
\n
"
);
stmt_funcb_autoctb_e8
(
stmt
);
printf
(
"e8 end
\n
"
);
taos_stmt_close
(
stmt
);
#endif
#if 1
#if 1
prepare
(
taos
,
1
,
0
);
prepare
(
taos
,
1
,
0
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录