Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
oceanbase
oceanbase
提交
ab9346b0
O
oceanbase
项目概览
oceanbase
/
oceanbase
9 个月 前同步成功
通知
261
Star
6084
Fork
1301
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
oceanbase
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
ab9346b0
编写于
4月 19, 2024
作者:
L
leftgeek
提交者:
ob-robot
4月 19, 2024
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add primary key constraint for materialized view log
上级
2f8121ba
变更
3
展开全部
隐藏空白更改
内联
并排
Showing
3 changed file
with
72 addition
and
24 deletion
+72
-24
src/rootserver/ob_ddl_service.cpp
src/rootserver/ob_ddl_service.cpp
+58
-10
src/share/inner_table/ob_inner_table_schema.25001_25050.cpp
src/share/inner_table/ob_inner_table_schema.25001_25050.cpp
+3
-3
src/share/inner_table/ob_inner_table_schema_def.py
src/share/inner_table/ob_inner_table_schema_def.py
+11
-11
未找到文件。
src/rootserver/ob_ddl_service.cpp
浏览文件 @
ab9346b0
...
...
@@ -693,16 +693,64 @@ int ObDDLService::create_mlog_table(
table_schema.get_tenant_id(), new_table_id))) {
LOG_WARN("failed to fetch new table id", KR(ret));
} else if (OB_FALSE_IT(table_schema.set_table_id(new_table_id))) {
} else if (OB_FAIL(create_index_or_mlog_table_in_trans(
table_schema,
&arg.ddl_stmt_str_,
&sql_trans,
schema_guard,
true /*need_check_tablet_cnt*/,
tenant_data_version))) {
LOG_WARN("failed to create index or mlog table in trans", KR(ret), K(arg.ddl_stmt_str_), K(table_schema));
} else if (OB_FAIL(add_mlog(sql_trans, arg, schema_guard, table_schema))) {
LOG_WARN("failed to add mlog", KR(ret));
} else if (is_oracle_mode) {
// add pk constraint
ObArenaAllocator allocator("CreateMlog");
ObString cst_name;
ObConstraint cst;
if (OB_FAIL(ObTableSchema::create_cons_name_automatically(
cst_name,
table_schema.get_table_name_str(),
allocator,
CONSTRAINT_TYPE_PRIMARY_KEY,
is_oracle_mode))) {
LOG_WARN("failed to create cons name automatically", KR(ret));
} else if (cst_name.length() > OB_MAX_CONSTRAINT_NAME_LENGTH_ORACLE) {
ret = OB_ERR_TOO_LONG_IDENT;
LOG_WARN("constraint_name length overflow", KR(ret), K(cst_name.length()));
} else if (OB_FAIL(cst.set_constraint_name(cst_name))) {
LOG_WARN("failed to set constraint name", KR(ret));
} else {
uint64_t new_cst_id = OB_INVALID_ID;
bool cst_name_exist = false;
cst.set_name_generated_type(GENERATED_TYPE_SYSTEM);
cst.set_constraint_type(CONSTRAINT_TYPE_PRIMARY_KEY);
cst.set_tenant_id(tenant_id);
cst.set_table_id(table_schema.get_table_id());
if (OB_FAIL(schema_service->fetch_new_constraint_id(tenant_id, new_cst_id))) {
LOG_WARN("failed to fetch new constraint id", K(ret));
} else if (FALSE_IT(cst.set_constraint_id(new_cst_id))) {
} else if (cst.get_constraint_name_str().empty()) {
ret = OB_ERR_UNEXPECTED;
LOG_WARN("cst name is empty", KR(ret));
} else if (OB_FAIL(check_constraint_name_is_exist(
schema_guard, table_schema, cst.get_constraint_name_str(), false, cst_name_exist))) {
LOG_WARN("failed to check constraint name is exist", KR(ret), K(cst.get_constraint_name_str()));
} else if (cst_name_exist) {
ret = OB_ERR_CONSTRAINT_NAME_DUPLICATE;
if (!is_oracle_mode) {
LOG_USER_ERROR(OB_ERR_CONSTRAINT_NAME_DUPLICATE,
cst.get_constraint_name_str().length(), cst.get_constraint_name_str().ptr());
}
LOG_WARN("cst name is duplicate", KR(ret), K(cst.get_constraint_name_str()));
} else if (OB_FAIL(table_schema.add_constraint(cst))) {
LOG_WARN("failed to add constraint", KR(ret));
}
}
}
if (OB_SUCC(ret)) {
if (OB_FAIL(create_index_or_mlog_table_in_trans(
table_schema,
&arg.ddl_stmt_str_,
&sql_trans,
schema_guard,
true /*need_check_tablet_cnt*/,
tenant_data_version))) {
LOG_WARN("failed to create index or mlog table in trans", KR(ret), K(arg.ddl_stmt_str_), K(table_schema));
} else if (OB_FAIL(add_mlog(sql_trans, arg, schema_guard, table_schema))) {
LOG_WARN("failed to add mlog", KR(ret));
}
}
return ret;
}
src/share/inner_table/ob_inner_table_schema.25001_25050.cpp
浏览文件 @
ab9346b0
此差异已折叠。
点击以展开。
src/share/inner_table/ob_inner_table_schema_def.py
浏览文件 @
ab9346b0
...
...
@@ -38640,7 +38640,7 @@ def_table_schema(
DATABASE_NAME AS TABLE_OWNER,
CASE WHEN (TABLE_TYPE
= 3
) THEN A.TABLE_ID
CASE WHEN (TABLE_TYPE
IN (3, 15)
) THEN A.TABLE_ID
ELSE A.DATA_TABLE_ID END AS TABLE_ID,
A.TABLE_ID AS INDEX_ID,
...
...
@@ -38652,7 +38652,7 @@ def_table_schema(
CASE WHEN A.COMPRESS_FUNC_NAME = NULL THEN 'DISABLED'
ELSE 'ENABLED' END AS COMPRESSION,
CASE WHEN TABLE_TYPE
= 3
THEN 'VALID'
CASE WHEN TABLE_TYPE
IN (3, 15)
THEN 'VALID'
WHEN A.INDEX_STATUS = 2 THEN 'VALID'
WHEN A.INDEX_STATUS = 3 THEN 'CHECKING'
WHEN A.INDEX_STATUS = 4 THEN 'INELEGIBLE'
...
...
@@ -38680,7 +38680,7 @@ def_table_schema(
SYS.ALL_VIRTUAL_TABLE_REAL_AGENT A
JOIN SYS.ALL_VIRTUAL_DATABASE_REAL_AGENT B
ON A.DATABASE_ID = B.DATABASE_ID
AND TABLE_TYPE IN (5, 3)
AND TABLE_TYPE IN (5, 3
, 15
)
AND A.TENANT_ID = EFFECTIVE_TENANT_ID()
AND bitand((A.TABLE_MODE / 4096), 15) IN (0,1)
AND B.TENANT_ID = EFFECTIVE_TENANT_ID()
...
...
@@ -38806,19 +38806,19 @@ def_table_schema(
DATABASE_NAME AS TABLE_OWNER,
CASE WHEN (TABLE_TYPE
= 3
) THEN A.TABLE_ID
CASE WHEN (TABLE_TYPE
IN (3, 15)
) THEN A.TABLE_ID
ELSE A.DATA_TABLE_ID END AS TABLE_ID,
A.TABLE_ID AS INDEX_ID,
CASE WHEN TABLE_TYPE
= 3
THEN 'UNIQUE'
CASE WHEN TABLE_TYPE
IN (3, 15)
THEN 'UNIQUE'
WHEN A.INDEX_TYPE IN (2, 4, 8) THEN 'UNIQUE'
ELSE 'NONUNIQUE' END AS UNIQUENESS,
CASE WHEN A.COMPRESS_FUNC_NAME = NULL THEN 'DISABLED'
ELSE 'ENABLED' END AS COMPRESSION,
CASE WHEN TABLE_TYPE
= 3
THEN 'VALID'
CASE WHEN TABLE_TYPE
IN (3, 15)
THEN 'VALID'
WHEN A.INDEX_STATUS = 2 THEN 'VALID'
WHEN A.INDEX_STATUS = 3 THEN 'CHECKING'
WHEN A.INDEX_STATUS = 4 THEN 'INELEGIBLE'
...
...
@@ -38846,7 +38846,7 @@ def_table_schema(
SYS.ALL_VIRTUAL_TABLE_REAL_AGENT A
JOIN SYS.ALL_VIRTUAL_DATABASE_REAL_AGENT B
ON A.DATABASE_ID = B.DATABASE_ID
AND TABLE_TYPE IN (5, 3)
AND TABLE_TYPE IN (5, 3
, 15
)
AND A.TENANT_ID = EFFECTIVE_TENANT_ID()
AND bitand((A.TABLE_MODE / 4096), 15) IN (0,1)
AND B.TENANT_ID = EFFECTIVE_TENANT_ID()
...
...
@@ -38975,19 +38975,19 @@ def_table_schema(
DATABASE_NAME AS TABLE_OWNER,
CASE WHEN (TABLE_TYPE
= 3
) THEN A.TABLE_ID
CASE WHEN (TABLE_TYPE
IN (3, 15)
) THEN A.TABLE_ID
ELSE A.DATA_TABLE_ID END AS TABLE_ID,
A.TABLE_ID AS INDEX_ID,
CASE WHEN TABLE_TYPE
= 3
THEN 'UNIQUE'
CASE WHEN TABLE_TYPE
IN (3, 15)
THEN 'UNIQUE'
WHEN A.INDEX_TYPE IN (2, 4, 8) THEN 'UNIQUE'
ELSE 'NONUNIQUE' END AS UNIQUENESS,
CASE WHEN A.COMPRESS_FUNC_NAME = NULL THEN 'DISABLED'
ELSE 'ENABLED' END AS COMPRESSION,
CASE WHEN TABLE_TYPE
= 3
THEN 'VALID'
CASE WHEN TABLE_TYPE
IN (3, 15)
THEN 'VALID'
WHEN A.INDEX_STATUS = 2 THEN 'VALID'
WHEN A.INDEX_STATUS = 3 THEN 'CHECKING'
WHEN A.INDEX_STATUS = 4 THEN 'INELEGIBLE'
...
...
@@ -39015,7 +39015,7 @@ def_table_schema(
SYS.ALL_VIRTUAL_TABLE_REAL_AGENT A
JOIN SYS.ALL_VIRTUAL_DATABASE_REAL_AGENT B
ON A.DATABASE_ID = B.DATABASE_ID
AND TABLE_TYPE IN (5, 3)
AND TABLE_TYPE IN (5, 3
, 15
)
AND A.TENANT_ID = EFFECTIVE_TENANT_ID()
AND bitand((A.TABLE_MODE / 4096), 15) IN (0,1)
AND B.TENANT_ID = EFFECTIVE_TENANT_ID()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录