add primary key constraint for materialized view log
This commit is contained in:
@ -693,16 +693,64 @@ int ObDDLService::create_mlog_table(
|
|||||||
table_schema.get_tenant_id(), new_table_id))) {
|
table_schema.get_tenant_id(), new_table_id))) {
|
||||||
LOG_WARN("failed to fetch new table id", KR(ret));
|
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_FALSE_IT(table_schema.set_table_id(new_table_id))) {
|
||||||
} else if (OB_FAIL(create_index_or_mlog_table_in_trans(
|
} else if (is_oracle_mode) {
|
||||||
table_schema,
|
// add pk constraint
|
||||||
&arg.ddl_stmt_str_,
|
ObArenaAllocator allocator("CreateMlog");
|
||||||
&sql_trans,
|
ObString cst_name;
|
||||||
schema_guard,
|
ObConstraint cst;
|
||||||
true /*need_check_tablet_cnt*/,
|
if (OB_FAIL(ObTableSchema::create_cons_name_automatically(
|
||||||
tenant_data_version))) {
|
cst_name,
|
||||||
LOG_WARN("failed to create index or mlog table in trans", KR(ret), K(arg.ddl_stmt_str_), K(table_schema));
|
table_schema.get_table_name_str(),
|
||||||
} else if (OB_FAIL(add_mlog(sql_trans, arg, schema_guard, table_schema))) {
|
allocator,
|
||||||
LOG_WARN("failed to add mlog", KR(ret));
|
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;
|
return ret;
|
||||||
}
|
}
|
||||||
|
File diff suppressed because one or more lines are too long
@ -38640,7 +38640,7 @@ def_table_schema(
|
|||||||
|
|
||||||
DATABASE_NAME AS TABLE_OWNER,
|
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,
|
ELSE A.DATA_TABLE_ID END AS TABLE_ID,
|
||||||
|
|
||||||
A.TABLE_ID AS INDEX_ID,
|
A.TABLE_ID AS INDEX_ID,
|
||||||
@ -38652,7 +38652,7 @@ def_table_schema(
|
|||||||
CASE WHEN A.COMPRESS_FUNC_NAME = NULL THEN 'DISABLED'
|
CASE WHEN A.COMPRESS_FUNC_NAME = NULL THEN 'DISABLED'
|
||||||
ELSE 'ENABLED' END AS COMPRESSION,
|
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 = 2 THEN 'VALID'
|
||||||
WHEN A.INDEX_STATUS = 3 THEN 'CHECKING'
|
WHEN A.INDEX_STATUS = 3 THEN 'CHECKING'
|
||||||
WHEN A.INDEX_STATUS = 4 THEN 'INELEGIBLE'
|
WHEN A.INDEX_STATUS = 4 THEN 'INELEGIBLE'
|
||||||
@ -38680,7 +38680,7 @@ def_table_schema(
|
|||||||
SYS.ALL_VIRTUAL_TABLE_REAL_AGENT A
|
SYS.ALL_VIRTUAL_TABLE_REAL_AGENT A
|
||||||
JOIN SYS.ALL_VIRTUAL_DATABASE_REAL_AGENT B
|
JOIN SYS.ALL_VIRTUAL_DATABASE_REAL_AGENT B
|
||||||
ON A.DATABASE_ID = B.DATABASE_ID
|
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 A.TENANT_ID = EFFECTIVE_TENANT_ID()
|
||||||
AND bitand((A.TABLE_MODE / 4096), 15) IN (0,1)
|
AND bitand((A.TABLE_MODE / 4096), 15) IN (0,1)
|
||||||
AND B.TENANT_ID = EFFECTIVE_TENANT_ID()
|
AND B.TENANT_ID = EFFECTIVE_TENANT_ID()
|
||||||
@ -38806,19 +38806,19 @@ def_table_schema(
|
|||||||
|
|
||||||
DATABASE_NAME AS TABLE_OWNER,
|
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,
|
ELSE A.DATA_TABLE_ID END AS TABLE_ID,
|
||||||
|
|
||||||
A.TABLE_ID AS INDEX_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'
|
WHEN A.INDEX_TYPE IN (2, 4, 8) THEN 'UNIQUE'
|
||||||
ELSE 'NONUNIQUE' END AS UNIQUENESS,
|
ELSE 'NONUNIQUE' END AS UNIQUENESS,
|
||||||
|
|
||||||
CASE WHEN A.COMPRESS_FUNC_NAME = NULL THEN 'DISABLED'
|
CASE WHEN A.COMPRESS_FUNC_NAME = NULL THEN 'DISABLED'
|
||||||
ELSE 'ENABLED' END AS COMPRESSION,
|
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 = 2 THEN 'VALID'
|
||||||
WHEN A.INDEX_STATUS = 3 THEN 'CHECKING'
|
WHEN A.INDEX_STATUS = 3 THEN 'CHECKING'
|
||||||
WHEN A.INDEX_STATUS = 4 THEN 'INELEGIBLE'
|
WHEN A.INDEX_STATUS = 4 THEN 'INELEGIBLE'
|
||||||
@ -38846,7 +38846,7 @@ def_table_schema(
|
|||||||
SYS.ALL_VIRTUAL_TABLE_REAL_AGENT A
|
SYS.ALL_VIRTUAL_TABLE_REAL_AGENT A
|
||||||
JOIN SYS.ALL_VIRTUAL_DATABASE_REAL_AGENT B
|
JOIN SYS.ALL_VIRTUAL_DATABASE_REAL_AGENT B
|
||||||
ON A.DATABASE_ID = B.DATABASE_ID
|
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 A.TENANT_ID = EFFECTIVE_TENANT_ID()
|
||||||
AND bitand((A.TABLE_MODE / 4096), 15) IN (0,1)
|
AND bitand((A.TABLE_MODE / 4096), 15) IN (0,1)
|
||||||
AND B.TENANT_ID = EFFECTIVE_TENANT_ID()
|
AND B.TENANT_ID = EFFECTIVE_TENANT_ID()
|
||||||
@ -38975,19 +38975,19 @@ def_table_schema(
|
|||||||
|
|
||||||
DATABASE_NAME AS TABLE_OWNER,
|
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,
|
ELSE A.DATA_TABLE_ID END AS TABLE_ID,
|
||||||
|
|
||||||
A.TABLE_ID AS INDEX_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'
|
WHEN A.INDEX_TYPE IN (2, 4, 8) THEN 'UNIQUE'
|
||||||
ELSE 'NONUNIQUE' END AS UNIQUENESS,
|
ELSE 'NONUNIQUE' END AS UNIQUENESS,
|
||||||
|
|
||||||
CASE WHEN A.COMPRESS_FUNC_NAME = NULL THEN 'DISABLED'
|
CASE WHEN A.COMPRESS_FUNC_NAME = NULL THEN 'DISABLED'
|
||||||
ELSE 'ENABLED' END AS COMPRESSION,
|
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 = 2 THEN 'VALID'
|
||||||
WHEN A.INDEX_STATUS = 3 THEN 'CHECKING'
|
WHEN A.INDEX_STATUS = 3 THEN 'CHECKING'
|
||||||
WHEN A.INDEX_STATUS = 4 THEN 'INELEGIBLE'
|
WHEN A.INDEX_STATUS = 4 THEN 'INELEGIBLE'
|
||||||
@ -39015,7 +39015,7 @@ def_table_schema(
|
|||||||
SYS.ALL_VIRTUAL_TABLE_REAL_AGENT A
|
SYS.ALL_VIRTUAL_TABLE_REAL_AGENT A
|
||||||
JOIN SYS.ALL_VIRTUAL_DATABASE_REAL_AGENT B
|
JOIN SYS.ALL_VIRTUAL_DATABASE_REAL_AGENT B
|
||||||
ON A.DATABASE_ID = B.DATABASE_ID
|
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 A.TENANT_ID = EFFECTIVE_TENANT_ID()
|
||||||
AND bitand((A.TABLE_MODE / 4096), 15) IN (0,1)
|
AND bitand((A.TABLE_MODE / 4096), 15) IN (0,1)
|
||||||
AND B.TENANT_ID = EFFECTIVE_TENANT_ID()
|
AND B.TENANT_ID = EFFECTIVE_TENANT_ID()
|
||||||
|
Reference in New Issue
Block a user