From 1240ca02f50a10f8671f255374e36a378a2b9f60 Mon Sep 17 00:00:00 2001
From: prinz <281208364@qq.com>
Date: Tue, 17 Oct 2023 15:12:18 +0800
Subject: [PATCH] add mo_transactions into sys-table
---
docs/MatrixOne/Reference/1.1-System-tables.md | 252 ++++++++++--------
1 file changed, 147 insertions(+), 105 deletions(-)
diff --git a/docs/MatrixOne/Reference/1.1-System-tables.md b/docs/MatrixOne/Reference/1.1-System-tables.md
index 7cd3a1960..9dc52ee2c 100644
--- a/docs/MatrixOne/Reference/1.1-System-tables.md
+++ b/docs/MatrixOne/Reference/1.1-System-tables.md
@@ -11,69 +11,22 @@ The system can only modify system databases and tables, and users can only read
Start with MatrixOne 0.6 has introduced the concept of multi-account, the default `sys` account and other accounts have slightly different behaviors. The system table `mo_account`, which serves the multi-tenancy management, is only visible for the `sys` account; the other accounts don't see this table.
-### mo_database table
-
-| Column | Type | comments |
-| ---------------- | --------------- | --------------------------------------- |
-| dat_id | bigint unsigned | Primary key ID |
-| datname | varchar(100) | Database name |
-| dat_catalog_name | varchar(100) | Database catalog name, default as `def` |
-| dat_createsql | varchar(100) | Database creation SQL statement |
-| owner | int unsigned | Role id |
-| creator | int unsigned | User id |
-| created_time | timestamp | Create time |
-| account_id | int unsigned | Account id |
-| dat_type | varchar(23) | Database type, common library or subscription library |
-
-### mo_tables table
-
-| Column | Type | comments |
-| -------------- | --------------- | ------------------------------------------------------------ |
-| rel_id | bigint unsigned | Primary key, table ID |
-| relname | varchar(100) | Name of the table, index, view, and so on. |
-| reldatabase | varchar(100) | The database that contains this relation. reference mo_database.datname |
-| reldatabase_id | bigint unsigned | The database id that contains this relation. reference mo_database.datid |
-| relpersistence | varchar(100) | p = permanent table, t = temporary table |
-| relkind | varchar(100) | r = ordinary table, e = external table, i = index, S = sequence, v = view, m = materialized view |
-| rel_comment | varchar(100) | |
-| rel_createsql | varchar(100) | Table creation SQL statement |
-| created_time | timestamp | Create time |
-| creator | int unsigned | Creator ID |
-| owner | int unsigned | Creator's default role id |
-| account_id | int unsigned | Account id |
-| partitioned | blob | Partition by statement |
-| partition_info | blob | the information of partition |
-| viewdef | blob | View definition statement |
-| constraint | varchar(5000) | Table related constraints |
-| rel_version | INT UNSIGNED(0) | Version number of Primary key or table |
-| catalog_version | INT UNSIGNED(0) | Version number of the system table |
-
-### mo_columns table
+### mo_indexes table
-| Column | type | comments |
-| --------------------- | --------------- | ------------------------------------------------------------ |
-| att_uniq_name | varchar(256) | Primary Key. Hidden, composite primary key, format is like "${att_relname_id}-${attname}" |
-| account_id | int unsigned | accountID |
-| att_database_id | bigint unsigned | databaseID |
-| att_database | varchar(256) | database Name |
-| att_relname_id | bigint unsigned | table id |
-| att_relname | varchar(256) | The table this column belongs to.(references mo_tables.relname) |
-| attname | varchar(256) | The column name |
-| atttyp | varchar(256) | The data type of this column (zero for a dropped column). |
-| attnum | int | The number of the column. Ordinary columns are numbered from 1 up. |
-| att_length | int | bytes count for the type. |
-| attnotnull | tinyint(1) | This represents a not-null constraint. |
-| atthasdef | tinyint(1) | This column has a default expression or generation expression. |
-| att_default | varchar(1024) | default expression |
-| attisdropped | tinyint(1) | This column has been dropped and is no longer valid. A dropped column is still physically present in the table, but is ignored by the parser and so cannot be accessed via SQL. |
-| att_constraint_type | char(1) | p = primary key constraint, n=no constraint |
-| att_is_unsigned | tinyint(1) | unsigned or not |
-| att_is_auto_increment | tinyint(1) | auto increment or not |
-| att_comment | varchar(1024) | comment |
-| att_is_hidden | tinyint(1) | hidden or not |
-| attr_has_update | tinyint(1) | This columns has update expression |
-| attr_update | varchar(1024) | update expression |
-| attr_is_clusterby | tinyint(1) | Whether this column is used as the cluster by keyword to create the table |
+| Column | Type | comments |
+| -----------------| --------------- | ----------------- |
+| id | BIGINT UNSIGNED(64) | index ID |
+| table_id | BIGINT UNSIGNED(64) | ID of the table where the index resides |
+| database_id | BIGINT UNSIGNED(64) | ID of the database where the index resides |
+| name | VARCHAR(64) | name of the index |
+| type | VARCHAR(11) | The type of index, including primary key index (PRIMARY), unique index (UNIQUE), secondary index (MULTIPLE) |
+| is_visible | TINYINT(8) | Whether the index is visible, 1 means visible, 0 means invisible (currently all MatrixOne indexes are visible indexes) |
+| hidden | TINYINT(8) | Whether the index is hidden, 1 is a hidden index, 0 is a non-hidden index|
+| comment | VARCHAR(2048) | Comment information for the index |
+| column_name | VARCHAR(256) | The column name of the constituent columns of the index |
+| ordinal_position | INT UNSIGNED(32) | Column ordinal in index, starting from 1 |
+| options | TEXT(0) | options option information for index |
+| index_table_name | VARCHAR(5000) | The table name of the index table corresponding to the index, currently only the unique index contains the index table |
### mo_table_partitions table
@@ -90,6 +43,22 @@ Start with MatrixOne 0.6 has introduced the concept of multi-account, the defaul
| options | TEXT(0) | Partition options information, currently set to NULL. |
| partition_table_name | VARCHAR(1024) | The name of the subtable corresponding to the current partition. |
+### mo_user table
+
+| Column | Type | comments |
+| --------------------- | ------------ | ------------------- |
+| user_id | int | user id, primary key |
+| user_host | varchar(100) | user host address |
+| user_name | varchar(100) | user name |
+| authentication_string | varchar(100) | authentication string encrypted with password |
+| status | varchar(8) | open,locked,expired |
+| created_time | timestamp | user created time |
+| expired_time | timestamp | user expired time |
+| login_type | varchar(16) | ssl/password/other |
+| creator | int | the creator id who created this user |
+| owner | int | the admin id for this user |
+| default_role | int | the default role id for this user |
+
### mo_account table (Only visible for `sys` account)
| Column | Type | comments |
@@ -102,6 +71,20 @@ Start with MatrixOne 0.6 has introduced the concept of multi-account, the defaul
| suspended_time | TIMESTAMP | Time of the account's status is changed |
| version | bigint unsigned | the version status of the current account|
+### mo_database table
+
+| Column | Type | comments |
+| ---------------- | --------------- | --------------------------------------- |
+| dat_id | bigint unsigned | Primary key ID |
+| datname | varchar(100) | Database name |
+| dat_catalog_name | varchar(100) | Database catalog name, default as `def` |
+| dat_createsql | varchar(100) | Database creation SQL statement |
+| owner | int unsigned | Role id |
+| creator | int unsigned | User id |
+| created_time | timestamp | Create time |
+| account_id | int unsigned | Account id |
+| dat_type | varchar(23) | Database type, common library or subscription library |
+
### mo_role table
| Column | Type | comments |
@@ -113,22 +96,6 @@ Start with MatrixOne 0.6 has introduced the concept of multi-account, the defaul
| created_time | timestamp | create time |
| comments | text | comment |
-### mo_user table
-
-| Column | Type | comments |
-| --------------------- | ------------ | ------------------- |
-| user_id | int | user id, primary key |
-| user_host | varchar(100) | user host address |
-| user_name | varchar(100) | user name |
-| authentication_string | varchar(100) | authentication string encrypted with password |
-| status | varchar(8) | open,locked,expired |
-| created_time | timestamp | user created time |
-| expired_time | timestamp | user expired time |
-| login_type | varchar(16) | ssl/password/other |
-| creator | int | the creator id who created this user |
-| owner | int | the admin id for this user |
-| default_role | int | the default role id for this user |
-
### mo_user_grant table
| Column | Type | comments |
@@ -164,18 +131,6 @@ Start with MatrixOne 0.6 has introduced the concept of multi-account, the defaul
| granted_time | timestamp | granted time |
| with_grant_option | bool | If permission granting is permitted |
-### mo_stages table
-
-| Column | Type | comments |
-| -----------------| ---------------- | ----------------- |
-| stage_id | INT UNSIGNED(32) | data stage ID |
-| stage_name | VARCHAR(64) | data stage name |
-| url | TEXT(0) | Path to object storage (without authentication), path to file system |
-| stage_credentials| TEXT(0) | Authentication information, encrypted and saved |
-| stage_status | VARCHAR(64) | ENABLED/DISABLED Default: DISABLED |
-| created_time | TIMESTAMP(0) | creation time |
-| comment | TEXT(0) | comment |
-
### mo_user_defined_function table
| Column | Type | comments |
@@ -223,22 +178,17 @@ Start with MatrixOne 0.6 has introduced the concept of multi-account, the defaul
| creator | INT UNSIGNED(32) | The ID of the user who created the release library |
| comment | TEXT(0) | Remarks for creating a release library |
-### mo_indexes table
+### mo_stages table
-| Column | Type | comments |
-| -----------------| --------------- | ----------------- |
-| id | BIGINT UNSIGNED(64) | index ID |
-| table_id | BIGINT UNSIGNED(64) | ID of the table where the index resides |
-| database_id | BIGINT UNSIGNED(64) | ID of the database where the index resides |
-| name | VARCHAR(64) | name of the index |
-| type | VARCHAR(11) | The type of index, including primary key index (PRIMARY), unique index (UNIQUE), secondary index (MULTIPLE) |
-| is_visible | TINYINT(8) | Whether the index is visible, 1 means visible, 0 means invisible (currently all MatrixOne indexes are visible indexes) |
-| hidden | TINYINT(8) | Whether the index is hidden, 1 is a hidden index, 0 is a non-hidden index|
-| comment | VARCHAR(2048) | Comment information for the index |
-| column_name | VARCHAR(256) | The column name of the constituent columns of the index |
-| ordinal_position | INT UNSIGNED(32) | Column ordinal in index, starting from 1 |
-| options | TEXT(0) | options option information for index |
-| index_table_name | VARCHAR(5000) | The table name of the index table corresponding to the index, currently only the unique index contains the index table |
+| Column | Type | comments |
+| -----------------| ---------------- | ----------------- |
+| stage_id | INT UNSIGNED(32) | data stage ID |
+| stage_name | VARCHAR(64) | data stage name |
+| url | TEXT(0) | Path to object storage (without authentication), path to file system |
+| stage_credentials| TEXT(0) | Authentication information, encrypted and saved |
+| stage_status | VARCHAR(64) | ENABLED/DISABLED Default: DISABLED |
+| created_time | TIMESTAMP(0) | creation time |
+| comment | TEXT(0) | comment |
### mo_sessions view
@@ -263,6 +213,17 @@ Start with MatrixOne 0.6 has introduced the concept of multi-account, the defaul
| client_host | VARCHAR(65535) | IP address and port of the client. |
| role | VARCHAR(65535) | Role name of the user. |
+### `mo_configurations` table
+
+| Column Name | Data Type | Description |
+| ------------- | --------------- | --------------------------------------- |
+| node_type | VARCHAR(65535) | Type of the node: cn, tn, log, proxy. |
+| node_id | VARCHAR(65535) | Unique identifier for the node. |
+| name | VARCHAR(65535) | Name of the configuration setting, prefixed with nested structure if applicable. |
+| current_value | VARCHAR(65535) | Current value of the configuration setting. |
+| default_value | VARCHAR(65535) | Default value of the configuration setting. |
+| internal | VARCHAR(65535) | Indicates whether the configuration parameter is internal. |
+
### mo_locks view
| Column | Type | comments |
@@ -275,6 +236,87 @@ Start with MatrixOne 0.6 has introduced the concept of multi-account, the defaul
| lock_status | VARCHAR(65535) | Lock status can be `wait`, `acquired`, or `none`.
`wait`: No transaction holds the lock, but transactions are waiting for it.
`acquired`: A transaction holds the lock.
`none`: No transaction holds the lock, and no transactions await it. |
| waiting_txns | VARCHAR(65535) | Transactions waiting on this lock. |
+### `mo_variables` view
+
+| Column | Type | comments |
+| ------------- | --------------- | ------------------------------------------------ |
+| configuration_id | INT(32) | Auto-incremented identifier for each configuration. |
+| account_id | INT(32) | Unique identifier for the account (tenant). |
+| account_name | VARCHAR(300) | Name of the account (tenant). |
+| dat_name | VARCHAR(5000)| Name of the database. |
+| variable_name | VARCHAR(300) | Name of the configuration variable. |
+| variable_value | VARCHAR(5000)| Value of the configuration variable. |
+| system_variables | BOOL(0) | Indicates whether the configuration variable is a system-level variable. |
+
+### `mo_transactions` view
+
+| Column | Type | comments |
+| ------------- | --------------- | ------------------------------------------------ |
+| cn_id | VARCHAR(65535) | Unique identifier for the CN (Compute Node). |
+| txn_id | VARCHAR(65535) | Unique identifier for the transaction. |
+| create_ts | VARCHAR(65535) | Records the transaction creation timestamp, following the RFC3339Nano format ("2006-01-02T15:04:05.999999999Z07:00"). |
+| snapshot_ts | VARCHAR(65535) | Represents the snapshot timestamp of the transaction, in a format that combines physical and logical time. |
+| prepared_ts | VARCHAR(65535) | Represents the prepared timestamp of the transaction, in a format that combines physical and logical time. |
+| commit_ts | VARCHAR(65535) | Represents the commit timestamp of the transaction, in a format that combines physical and logical time. |
+| txn_mode | VARCHAR(65535) | Indicates the transaction mode, which can be either pessimistic or optimistic. |
+| isolation | VARCHAR(65535) | Represents the isolation level of the transaction, which can be SI (Snapshot Isolation) or RC (Read Committed). |
+| user_txn | VARCHAR(65535) | Indicates a user transaction, i.e., a transaction created by SQL operations executed by a user connecting to MatrixOne via a client. |
+| txn_status | VARCHAR(65535) | Represents the current status of the transaction, with possible values including active, committed, aborting, aborted. In distributed transaction 2PC mode, it may also include prepared and committing. |
+| table_id | VARCHAR(65535) | Represents the ID of the table involved in the transaction. |
+| lock_key | VARCHAR(65535) | Represents the type of lock, which can be either range (range lock) or point (point lock). |
+| lock_content | VARCHAR(65535) | Represents the value for a point lock or a range for a range lock, usually in the form "low - high." Please note that a transaction may involve multiple locks, but only the first lock is displayed here. |
+| lock_mode | VARCHAR(65535) | Represents the lock mode, which can be either exclusive or shared. |
+
+### mo_columns table
+
+| Column | type | comments |
+| --------------------- | --------------- | ------------------------------------------------------------ |
+| att_uniq_name | varchar(256) | Primary Key. Hidden, composite primary key, format is like "${att_relname_id}-${attname}" |
+| account_id | int unsigned | accountID |
+| att_database_id | bigint unsigned | databaseID |
+| att_database | varchar(256) | database Name |
+| att_relname_id | bigint unsigned | table id |
+| att_relname | varchar(256) | The table this column belongs to.(references mo_tables.relname) |
+| attname | varchar(256) | The column name |
+| atttyp | varchar(256) | The data type of this column (zero for a dropped column). |
+| attnum | int | The number of the column. Ordinary columns are numbered from 1 up. |
+| att_length | int | bytes count for the type. |
+| attnotnull | tinyint(1) | This represents a not-null constraint. |
+| atthasdef | tinyint(1) | This column has a default expression or generation expression. |
+| att_default | varchar(1024) | default expression |
+| attisdropped | tinyint(1) | This column has been dropped and is no longer valid. A dropped column is still physically present in the table, but is ignored by the parser and so cannot be accessed via SQL. |
+| att_constraint_type | char(1) | p = primary key constraint, n=no constraint |
+| att_is_unsigned | tinyint(1) | unsigned or not |
+| att_is_auto_increment | tinyint(1) | auto increment or not |
+| att_comment | varchar(1024) | comment |
+| att_is_hidden | tinyint(1) | hidden or not |
+| attr_has_update | tinyint(1) | This columns has update expression |
+| attr_update | varchar(1024) | update expression |
+| attr_is_clusterby | tinyint(1) | Whether this column is used as the cluster by keyword to create the table |
+
+### mo_tables table
+
+| Column | Type | comments |
+| -------------- | --------------- | ------------------------------------------------------------ |
+| rel_id | bigint unsigned | Primary key, table ID |
+| relname | varchar(100) | Name of the table, index, view, and so on. |
+| reldatabase | varchar(100) | The database that contains this relation. reference mo_database.datname |
+| reldatabase_id | bigint unsigned | The database id that contains this relation. reference mo_database.datid |
+| relpersistence | varchar(100) | p = permanent table, t = temporary table |
+| relkind | varchar(100) | r = ordinary table, e = external table, i = index, S = sequence, v = view, m = materialized view |
+| rel_comment | varchar(100) | |
+| rel_createsql | varchar(100) | Table creation SQL statement |
+| created_time | timestamp | Create time |
+| creator | int unsigned | Creator ID |
+| owner | int unsigned | Creator's default role id |
+| account_id | int unsigned | Account id |
+| partitioned | blob | Partition by statement |
+| partition_info | blob | the information of partition |
+| viewdef | blob | View definition statement |
+| constraint | varchar(5000) | Table related constraints |
+| rel_version | INT UNSIGNED(0) | Version number of Primary key or table |
+| catalog_version | INT UNSIGNED(0) | Version number of the system table |
+
## `system_metrics` database
`system_metrics` collect the status and statistics of SQL statements, CPU & memory resource usage.