Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
d81727af
TDengine
项目概览
taosdata
/
TDengine
大约 2 年 前同步成功
通知
1192
Star
22018
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看板
未验证
提交
d81727af
编写于
7月 21, 2023
作者:
D
dapan1121
提交者:
GitHub
7月 21, 2023
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #22130 from taosdata/fix/TD-25270
enh: support show create table for system tables
上级
fde8eabf
ded3ee67
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
32 addition
and
4 deletion
+32
-4
source/dnode/mnode/impl/inc/mndStb.h
source/dnode/mnode/impl/inc/mndStb.h
+1
-0
source/dnode/mnode/impl/src/mndStb.c
source/dnode/mnode/impl/src/mndStb.c
+11
-2
source/libs/catalog/src/ctgAsync.c
source/libs/catalog/src/ctgAsync.c
+2
-2
tests/system-test/0-others/show.py
tests/system-test/0-others/show.py
+18
-0
未找到文件。
source/dnode/mnode/impl/inc/mndStb.h
浏览文件 @
d81727af
...
@@ -39,6 +39,7 @@ int32_t mndBuildSMCreateStbRsp(SMnode *pMnode, char *dbFName, char *stbFName, vo
...
@@ -39,6 +39,7 @@ int32_t mndBuildSMCreateStbRsp(SMnode *pMnode, char *dbFName, char *stbFName, vo
void
mndExtractDbNameFromStbFullName
(
const
char
*
stbFullName
,
char
*
dst
);
void
mndExtractDbNameFromStbFullName
(
const
char
*
stbFullName
,
char
*
dst
);
void
mndExtractShortDbNameFromStbFullName
(
const
char
*
stbFullName
,
char
*
dst
);
void
mndExtractShortDbNameFromStbFullName
(
const
char
*
stbFullName
,
char
*
dst
);
void
mndExtractShortDbNameFromDbFullName
(
const
char
*
stbFullName
,
char
*
dst
);
void
mndExtractTbNameFromStbFullName
(
const
char
*
stbFullName
,
char
*
dst
,
int32_t
dstSize
);
void
mndExtractTbNameFromStbFullName
(
const
char
*
stbFullName
,
char
*
dst
,
int32_t
dstSize
);
const
char
*
mndGetStbStr
(
const
char
*
src
);
const
char
*
mndGetStbStr
(
const
char
*
src
);
...
...
source/dnode/mnode/impl/src/mndStb.c
浏览文件 @
d81727af
...
@@ -2498,12 +2498,14 @@ static int32_t mndProcessTableCfgReq(SRpcMsg *pReq) {
...
@@ -2498,12 +2498,14 @@ static int32_t mndProcessTableCfgReq(SRpcMsg *pReq) {
goto
_OVER
;
goto
_OVER
;
}
}
if
(
0
==
strcmp
(
cfgReq
.
dbFName
,
TSDB_INFORMATION_SCHEMA_DB
))
{
char
dbName
[
TSDB_DB_NAME_LEN
]
=
{
0
};
mndExtractShortDbNameFromDbFullName
(
cfgReq
.
dbFName
,
dbName
);
if
(
0
==
strcmp
(
dbName
,
TSDB_INFORMATION_SCHEMA_DB
))
{
mInfo
(
"information_schema table:%s.%s, start to retrieve cfg"
,
cfgReq
.
dbFName
,
cfgReq
.
tbName
);
mInfo
(
"information_schema table:%s.%s, start to retrieve cfg"
,
cfgReq
.
dbFName
,
cfgReq
.
tbName
);
if
(
mndBuildInsTableCfg
(
pMnode
,
cfgReq
.
dbFName
,
cfgReq
.
tbName
,
&
cfgRsp
)
!=
0
)
{
if
(
mndBuildInsTableCfg
(
pMnode
,
cfgReq
.
dbFName
,
cfgReq
.
tbName
,
&
cfgRsp
)
!=
0
)
{
goto
_OVER
;
goto
_OVER
;
}
}
}
else
if
(
0
==
strcmp
(
cfgReq
.
dbF
Name
,
TSDB_PERFORMANCE_SCHEMA_DB
))
{
}
else
if
(
0
==
strcmp
(
db
Name
,
TSDB_PERFORMANCE_SCHEMA_DB
))
{
mInfo
(
"performance_schema table:%s.%s, start to retrieve cfg"
,
cfgReq
.
dbFName
,
cfgReq
.
tbName
);
mInfo
(
"performance_schema table:%s.%s, start to retrieve cfg"
,
cfgReq
.
dbFName
,
cfgReq
.
tbName
);
if
(
mndBuildPerfsTableCfg
(
pMnode
,
cfgReq
.
dbFName
,
cfgReq
.
tbName
,
&
cfgRsp
)
!=
0
)
{
if
(
mndBuildPerfsTableCfg
(
pMnode
,
cfgReq
.
dbFName
,
cfgReq
.
tbName
,
&
cfgRsp
)
!=
0
)
{
goto
_OVER
;
goto
_OVER
;
...
@@ -2672,6 +2674,13 @@ void mndExtractShortDbNameFromStbFullName(const char *stbFullName, char *dst) {
...
@@ -2672,6 +2674,13 @@ void mndExtractShortDbNameFromStbFullName(const char *stbFullName, char *dst) {
tNameGetDbName
(
&
name
,
dst
);
tNameGetDbName
(
&
name
,
dst
);
}
}
void
mndExtractShortDbNameFromDbFullName
(
const
char
*
stbFullName
,
char
*
dst
)
{
SName
name
=
{
0
};
tNameFromString
(
&
name
,
stbFullName
,
T_NAME_ACCT
|
T_NAME_DB
);
tNameGetDbName
(
&
name
,
dst
);
}
void
mndExtractTbNameFromStbFullName
(
const
char
*
stbFullName
,
char
*
dst
,
int32_t
dstSize
)
{
void
mndExtractTbNameFromStbFullName
(
const
char
*
stbFullName
,
char
*
dst
,
int32_t
dstSize
)
{
int32_t
pos
=
-
1
;
int32_t
pos
=
-
1
;
int32_t
num
=
0
;
int32_t
num
=
0
;
...
...
source/libs/catalog/src/ctgAsync.c
浏览文件 @
d81727af
...
@@ -2090,7 +2090,7 @@ int32_t ctgLaunchGetTbCfgTask(SCtgTask* pTask) {
...
@@ -2090,7 +2090,7 @@ int32_t ctgLaunchGetTbCfgTask(SCtgTask* pTask) {
}
}
CTG_CACHE_NHIT_INC
(
CTG_CI_TBL_CFG
,
1
);
CTG_CACHE_NHIT_INC
(
CTG_CI_TBL_CFG
,
1
);
if
(
pCtx
->
tbType
<=
0
)
{
if
(
pCtx
->
tbType
<=
0
)
{
CTG_ERR_JRET
(
ctgReadTbTypeFromCache
(
pCtg
,
dbFName
,
pCtx
->
pName
->
tname
,
&
pCtx
->
tbType
));
CTG_ERR_JRET
(
ctgReadTbTypeFromCache
(
pCtg
,
dbFName
,
pCtx
->
pName
->
tname
,
&
pCtx
->
tbType
));
if
(
pCtx
->
tbType
<=
0
)
{
if
(
pCtx
->
tbType
<=
0
)
{
...
@@ -2102,7 +2102,7 @@ int32_t ctgLaunchGetTbCfgTask(SCtgTask* pTask) {
...
@@ -2102,7 +2102,7 @@ int32_t ctgLaunchGetTbCfgTask(SCtgTask* pTask) {
}
}
}
}
if
(
TSDB_SUPER_TABLE
==
pCtx
->
tbType
)
{
if
(
TSDB_SUPER_TABLE
==
pCtx
->
tbType
||
TSDB_SYSTEM_TABLE
==
pCtx
->
tbType
)
{
CTG_ERR_JRET
(
ctgGetTableCfgFromMnode
(
pCtg
,
pConn
,
pCtx
->
pName
,
NULL
,
pTask
));
CTG_ERR_JRET
(
ctgGetTableCfgFromMnode
(
pCtg
,
pConn
,
pCtx
->
pName
,
NULL
,
pTask
));
}
else
{
}
else
{
if
(
NULL
==
pCtx
->
pVgInfo
)
{
if
(
NULL
==
pCtx
->
pVgInfo
)
{
...
...
tests/system-test/0-others/show.py
浏览文件 @
d81727af
...
@@ -95,6 +95,23 @@ class TDTestCase:
...
@@ -95,6 +95,23 @@ class TDTestCase:
tdSql
.
checkEqual
(
f
'
{
db
}
'
,
tdSql
.
queryResult
[
0
][
0
])
tdSql
.
checkEqual
(
f
'
{
db
}
'
,
tdSql
.
queryResult
[
0
][
0
])
tdSql
.
checkEqual
(
f
'CREATE DATABASE `
{
db
}
`'
,
tdSql
.
queryResult
[
0
][
1
])
tdSql
.
checkEqual
(
f
'CREATE DATABASE `
{
db
}
`'
,
tdSql
.
queryResult
[
0
][
1
])
def
show_create_systb_sql
(
self
):
for
param
in
self
.
ins_param_list
:
tdSql
.
query
(
f
'show create table information_schema.ins_
{
param
}
'
)
tdSql
.
checkEqual
(
f
'ins_
{
param
}
'
,
tdSql
.
queryResult
[
0
][
0
])
tdSql
.
execute
(
f
'use information_schema'
)
tdSql
.
query
(
f
'show create table ins_
{
param
}
'
)
tdSql
.
checkEqual
(
f
'ins_
{
param
}
'
,
tdSql
.
queryResult
[
0
][
0
])
for
param
in
self
.
perf_param_list
:
tdSql
.
query
(
f
'show create table performance_schema.perf_
{
param
}
'
)
tdSql
.
checkEqual
(
f
'perf_
{
param
}
'
,
tdSql
.
queryResult
[
0
][
0
])
tdSql
.
execute
(
f
'use performance_schema'
)
tdSql
.
query
(
f
'show create table perf_
{
param
}
'
)
tdSql
.
checkEqual
(
f
'perf_
{
param
}
'
,
tdSql
.
queryResult
[
0
][
0
])
def
show_create_sql
(
self
):
def
show_create_sql
(
self
):
create_db_sql
=
self
.
set_create_database_sql
(
self
.
db_param
)
create_db_sql
=
self
.
set_create_database_sql
(
self
.
db_param
)
print
(
create_db_sql
)
print
(
create_db_sql
)
...
@@ -200,6 +217,7 @@ class TDTestCase:
...
@@ -200,6 +217,7 @@ class TDTestCase:
self
.
perf_check
()
self
.
perf_check
()
self
.
show_create_sql
()
self
.
show_create_sql
()
self
.
show_create_sysdb_sql
()
self
.
show_create_sysdb_sql
()
self
.
show_create_systb_sql
()
def
stop
(
self
):
def
stop
(
self
):
tdSql
.
close
()
tdSql
.
close
()
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录