Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
c40730b7
T
TDengine
项目概览
taosdata
/
TDengine
大约 2 年 前同步成功
通知
1192
Star
22018
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看板
未验证
提交
c40730b7
编写于
8月 27, 2021
作者:
D
dapan1121
提交者:
GitHub
8月 27, 2021
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #7642 from taosdata/fix/TS-165
Fix/ts 165 fix space judge error
上级
77a6071a
b55813cf
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
54 addition
and
4 deletion
+54
-4
src/client/src/tscParseInsert.c
src/client/src/tscParseInsert.c
+3
-2
src/plugins/http/src/httpParser.c
src/plugins/http/src/httpParser.c
+1
-1
src/util/src/ttokenizer.c
src/util/src/ttokenizer.c
+1
-1
tests/pytest/fulltest.sh
tests/pytest/fulltest.sh
+1
-0
tests/pytest/insert/specialSql.py
tests/pytest/insert/specialSql.py
+48
-0
未找到文件。
src/client/src/tscParseInsert.c
浏览文件 @
c40730b7
...
...
@@ -114,7 +114,7 @@ int tsParseTime(SStrToken *pToken, int64_t *time, char **next, char *error, int1
}
for
(
int
k
=
pToken
->
n
;
pToken
->
z
[
k
]
!=
'\0'
;
k
++
)
{
if
(
pToken
->
z
[
k
]
==
' '
||
pToken
->
z
[
k
]
==
'\t'
)
continue
;
if
(
isspace
(
pToken
->
z
[
k
])
)
continue
;
if
(
pToken
->
z
[
k
]
==
','
)
{
*
next
=
pTokenEnd
;
*
time
=
useconds
;
...
...
@@ -1589,7 +1589,8 @@ int tsParseSql(SSqlObj *pSql, bool initial) {
ret
=
tsParseInsertSql
(
pSql
);
if
(
pSql
->
parseRetry
<
1
&&
(
ret
==
TSDB_CODE_TSC_SQL_SYNTAX_ERROR
||
ret
==
TSDB_CODE_TSC_INVALID_OPERATION
))
{
tscDebug
(
"0x%"
PRIx64
" parse insert sql statement failed, code:%s, clear meta cache and retry "
,
pSql
->
self
,
tstrerror
(
ret
));
SInsertStatementParam
*
pInsertParam
=
&
pCmd
->
insertParam
;
tscDebug
(
"0x%"
PRIx64
" parse insert sql statement failed, code:%s, msg:%s, clear meta cache and retry "
,
pSql
->
self
,
pInsertParam
->
msg
,
tstrerror
(
ret
));
tscResetSqlCmd
(
pCmd
,
true
);
pSql
->
parseRetry
++
;
...
...
src/plugins/http/src/httpParser.c
浏览文件 @
c40730b7
...
...
@@ -663,7 +663,7 @@ static int32_t httpParserOnTarget(HttpParser *parser, HTTP_PARSER_STATE state, c
HttpContext
*
pContext
=
parser
->
pContext
;
int32_t
ok
=
0
;
do
{
if
(
!
isspace
(
c
)
&&
c
!=
'\r'
&&
c
!=
'\n'
)
{
if
(
!
isspace
(
c
))
{
if
(
httpAppendString
(
&
parser
->
str
,
&
c
,
1
))
{
httpError
(
"context:%p, fd:%d, parser state:%d, char:[%c]%02x, oom"
,
pContext
,
pContext
->
fd
,
state
,
c
,
c
);
ok
=
-
1
;
...
...
src/util/src/ttokenizer.c
浏览文件 @
c40730b7
...
...
@@ -608,7 +608,7 @@ SStrToken tStrGetToken(char* str, int32_t* i, bool isPrevOptr) {
int32_t
numOfComma
=
0
;
char
t
=
str
[
*
i
];
while
(
t
==
' '
||
t
==
'\n'
||
t
==
'\r'
||
t
==
'\t'
||
t
==
'\f'
||
t
==
','
)
{
while
(
isspace
(
t
)
||
t
==
','
)
{
if
(
t
==
','
&&
(
++
numOfComma
>
1
))
{
// comma only allowed once
t0
.
n
=
0
;
return
t0
;
...
...
tests/pytest/fulltest.sh
浏览文件 @
c40730b7
...
...
@@ -28,6 +28,7 @@ python3 ./test.py -f insert/insertDynamicColBeforeVal.py
python3 ./test.py
-f
insert/in_function.py
python3 ./test.py
-f
insert/modify_column.py
python3 ./test.py
-f
insert/line_insert.py
python3 ./test.py
-f
insert/specialSql.py
#table
python3 ./test.py
-f
table/alter_wal0.py
...
...
tests/pytest/insert/specialSql.py
0 → 100644
浏览文件 @
c40730b7
###################################################################
# Copyright (c) 2016 by TAOS Technologies, Inc.
# All rights reserved.
#
# This file is proprietary and confidential to TAOS Technologies.
# No part of this file may be reproduced, stored, transmitted,
# disclosed or used in any form or by any means other than as
# expressly provided by the written permission from Jianhui Tao
#
###################################################################
# -*- coding: utf-8 -*-
import
sys
from
util.log
import
*
from
util.cases
import
*
from
util.sql
import
*
from
util.dnodes
import
*
class
TDTestCase
:
def
init
(
self
,
conn
,
logSql
):
tdLog
.
debug
(
"start to execute %s"
%
__file__
)
tdSql
.
init
(
conn
.
cursor
(),
logSql
)
def
run
(
self
):
tdSql
.
prepare
()
tdLog
.
info
(
"=============== step1"
)
tdSql
.
execute
(
'create stable properties_asch5snuykd (ts timestamp, create_time timestamp, number_value double, value int) tags (device_id nchar(8), property nchar(8))'
)
tdSql
.
execute
(
"insert into
\n\t\t
\n\t\t\t
db.properties_b86ca7d11556e0fdd43fd12ac08651f9 using db.properties_asch5snuykd
\n\t\t\t
(
\n\t\t\t
\n\t\t\t\t
device_id
\n\t\t\t
,
\n\t\t\t\t
property
\n\t\t\t
\n\t\t\t
)
\n\t\t\t
tags
\n\t\t\t
(
\n\t\t\t
\n\t\t\t\t
'dev1'
\n\t\t\t
,
\n\t\t\t\t
'pres'
\n\t\t\t
\n\t\t\t
)
\n\t\t\t
(
\n\t\t\t
\n\t\t\t\t
ts
\n\t\t\t
,
\n\t\t\t\t
create_time
\n\t\t\t
,
\n\t\t\t\t
number_value
\n\t\t\t
,
\n\t\t\t\t
value
\n\t\t\t
\n\t\t\t
)
\n\t\t\t
values
\n\t\t\t
\n\t\t\t\t
(
\n\t\t\t\t
\n\t\t\t\t\t
1629443494659
\n\t\t\t\t
,
\n\t\t\t\t\t
1629443494660
\n\t\t\t\t
,
\n\t\t\t\t\t
-1000.0
\n\t\t\t\t
,
\n\t\t\t\t\t
'-1000'
\n\t\t\t\t
\n\t\t\t\t
)
\n
;"
)
tdSql
.
query
(
"select * from db.properties_b86ca7d11556e0fdd43fd12ac08651f9"
)
tdSql
.
checkRows
(
1
)
def
stop
(
self
):
tdSql
.
close
()
tdLog
.
success
(
"%s successfully executed"
%
__file__
)
tdCases
.
addWindows
(
__file__
,
TDTestCase
())
tdCases
.
addLinux
(
__file__
,
TDTestCase
())
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录