Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
慢慢CG
TDengine
提交
747e9326
T
TDengine
项目概览
慢慢CG
/
TDengine
与 Fork 源项目一致
Fork自
taosdata / TDengine
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
747e9326
编写于
8月 13, 2019
作者:
H
huili
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[no master key column use timestamp in where]
上级
0ee234ad
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
33 addition
and
4 deletion
+33
-4
src/client/src/tscSQLParser.c
src/client/src/tscSQLParser.c
+33
-4
未找到文件。
src/client/src/tscSQLParser.c
浏览文件 @
747e9326
...
...
@@ -2408,7 +2408,31 @@ void setColumnOffsetValueInResultset(SSqlCmd* pCmd) {
}
}
static
void
setColumnFilterInfo
(
SSqlCmd
*
pCmd
,
SColumnBase
*
pColFilter
,
int32_t
colIdx
,
tSQLExpr
*
pExpr
)
{
static
int
setColumnFilterInfoForTimestamp
(
SSqlCmd
*
pCmd
,
tVariant
*
pVar
)
{
int64_t
time
=
0
;
const
char
*
msg
=
"invalid timestamp"
;
strdequote
(
pVar
->
pz
);
char
*
seg
=
strnchr
(
pVar
->
pz
,
'-'
,
pVar
->
nLen
,
false
);
if
(
seg
!=
NULL
)
{
if
(
taosParseTime
(
pVar
->
pz
,
&
time
,
pVar
->
nLen
,
pCmd
->
pMeterMeta
->
precision
)
!=
TSDB_CODE_SUCCESS
)
{
setErrMsg
(
pCmd
,
msg
);
return
TSDB_CODE_INVALID_SQL
;
}
}
else
{
if
(
tVariantDump
(
pVar
,
(
char
*
)
&
time
,
TSDB_DATA_TYPE_BIGINT
))
{
setErrMsg
(
pCmd
,
msg
);
return
TSDB_CODE_INVALID_SQL
;
}
}
tVariantDestroy
(
pVar
);
tVariantCreateB
(
pVar
,
&
time
,
0
,
TSDB_DATA_TYPE_BIGINT
);
return
TSDB_CODE_SUCCESS
;
}
static
int
setColumnFilterInfo
(
SSqlCmd
*
pCmd
,
SColumnBase
*
pColFilter
,
int32_t
colIdx
,
tSQLExpr
*
pExpr
)
{
tSQLExpr
*
pRight
=
pExpr
->
pRight
;
SSchema
*
pSchema
=
tsGetSchema
(
pCmd
->
pMeterMeta
);
...
...
@@ -2417,10 +2441,15 @@ static void setColumnFilterInfo(SSqlCmd* pCmd, SColumnBase* pColFilter, int32_t
pColFilter
->
colIndex
=
colIdx
;
int16_t
colType
=
pSchema
[
colIdx
].
type
;
if
(
(
colType
>=
TSDB_DATA_TYPE_TINYINT
&&
colType
<=
TSDB_DATA_TYPE_BIGINT
)
||
colType
==
TSDB_DATA_TYPE_TIMESTAMP
)
{
if
(
colType
>=
TSDB_DATA_TYPE_TINYINT
&&
colType
<=
TSDB_DATA_TYPE_BIGINT
)
{
colType
=
TSDB_DATA_TYPE_BIGINT
;
}
else
if
(
colType
==
TSDB_DATA_TYPE_FLOAT
||
colType
==
TSDB_DATA_TYPE_DOUBLE
)
{
colType
=
TSDB_DATA_TYPE_DOUBLE
;
}
else
if
((
colType
==
TSDB_DATA_TYPE_TIMESTAMP
)
&&
(
TSDB_DATA_TYPE_BINARY
==
pRight
->
val
.
nType
))
{
int
retVal
=
setColumnFilterInfoForTimestamp
(
pCmd
,
&
pRight
->
val
);
if
(
TSDB_CODE_SUCCESS
!=
retVal
)
{
return
retVal
;
}
}
if
(
pExpr
->
nSQLOptr
==
TK_LE
||
pExpr
->
nSQLOptr
==
TK_LT
)
{
...
...
@@ -2460,6 +2489,7 @@ static void setColumnFilterInfo(SSqlCmd* pCmd, SColumnBase* pColFilter, int32_t
pColFilter
->
lowerRelOptr
=
TSDB_RELATION_LIKE
;
break
;
}
return
TSDB_CODE_SUCCESS
;
}
static
int32_t
getTimeRange
(
int64_t
*
stime
,
int64_t
*
etime
,
tSQLExpr
*
pRight
,
int32_t
optr
,
int16_t
precision
);
...
...
@@ -2808,8 +2838,7 @@ static int32_t getColumnFilterInfo(SSqlCmd* pCmd, int32_t colIdx, tSQLExpr* pExp
}
}
setColumnFilterInfo
(
pCmd
,
pColFilter
,
colIdx
,
pExpr
);
return
TSDB_CODE_SUCCESS
;
return
setColumnFilterInfo
(
pCmd
,
pColFilter
,
colIdx
,
pExpr
);
}
static
int32_t
handleExprInQueryCond
(
SSqlCmd
*
pCmd
,
bool
*
queryTimeRangeIsSet
,
char
**
queryStr
,
int64_t
*
stime
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录