Tsurugi 1.0.0 - Known Issues (en) #101
akirakw
announced in
Announcements
Replies: 0 comments
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
-
1.0.0 Known Issues
Resolved Issues
The following are important issues resolved in this version that require the attention of existing users.
TSURUGI-IS-923 When DROP TABLE statement removes tables with any records, then the records will remain in the transaction logs with inconsistent state.
Problem:
When a table with any records is deleted using the
DROP TABLE
statement, running the log compaction tool afterward may not free up disk space. This is because the record data of the deleted table remains in the transaction log.Additionally, if the Tsurugi server is launched with such the state of transaction logs, it will take more time to launch and consume memory cause of the remaining unnecessary logs.
Note that the table management information is deleted, so the deleted table cannot be accessed.
To avoid this issue, execute a
DELETE
statement or similar to empty the table before executingDROP TABLE
.Status:
Fixed in version
1.0.0
. However, if inconsistent transaction logs from versions prior to1.0.0
are migrated to this version, running the log compaction tool will not resolve the inconsistency.Inconsistent transaction logs from older versions should not be migrated using the normal upgrade procedure. Instead, start a new Tsurugi server with version
1.0.0
and perform data migration.Known Issues
The following are unresolved issues in this version.
Unless otherwise noted, these issues are planned to be fixed or mitigated in future versions.
TSURUGI-IS-177 Executing DDL during DML processing can cause the database to become unstable.
Problem:
Executing DDL statements such as
CREATE TABLE
orDROP TABLE
during the execution of DML statements likeSELECT
orINSERT
can cause the database to become unstable.To avoid this situation, ensure to complete DDL statements before starting any DML statements, so that their execution times do not overlap.
TSURUGI-IS-252 Cannot create an index on a non-empty table.
Problem:
When creating an index using the
CREATE INDEX
statement, an error occurs if the target table contains data.Note
Workaround:
Empty the table before creating the index.
You can temporalily dump the table to escape the table data, and then load back the data to the table after creating indexes.
TSURUGI-IS-289 Database startup becomes slower as the transaction log increases.
Problem:
When the database is started with a large amount of data in the transaction log, the startup time becomes longer.
Below are examples of the number of records, transaction log size, and database startup time for table data with a each record size of approximately 200 bytes.
Additionally, the transaction log increases with each write to the database, and deleting rows does not immediate decrease the log.
Note
Workaround:
Using the log compaction tool to compress the transaction log may shorten the database startup time.
This tool reduces the log size by consolidating multiple operations on the same row and removing information about deleted rows from the log.
Version
1.0.0
provides two types of log compaction tools.The following commands are located in the
bin
directory under the Tsurugi installation directory.tglogutil compaction
: Offline Log Compaction Tooltglogutil compaction
can compress transaction log files while the database is stopped.For details on the command, refer to the following document:
tglogutil-compaction
- reorganize a Tsurugi transaction log directorytgcmpct_logs.sh
: (Experimental Feature) Online Log Compaction Tooltgcmpct_logs.sh
can compress transaction log files while the database is running.This command does not actually delete the log files even if some files become unnecessary as a result of compaction.
To delete such the log files, please execute
tgdel_logs.sh
separately.tgdel_logs.sh
actually deletes such the unnecessary files, as a result of executingtgcmpct_logs.sh
, from the file system.Basically, use
tgcmpct_logs.sh
andtgdel_logs.sh
in combination.This feature is currently experimental. These commands and features are subject to change upon official support.
It is recommended to take a backup of the database before using this feature.
TSURUGI-IS-448 Interrupting execution of DDL can leave the table definitions inconsistent
Problem:
If a transaction that executes DDL statements such as
CREATE TABLE
orDROP TABLE
is aborted or rolled back, the internal table management information in Tsurugi becomes inconsistent. Operations on tables in this inconsistent state may return incorrect results.For example, executing the following SQL steps will result in an inconsistent table state:
If the above situation occurs, promptly execute
DROP TABLE
to delete the table.TSURUGI-IS-702 Deleting tables invalidates prepared statements for the table
Problem:
If a
DROP TABLE
is executed on a target table while holding a PreparedStatement, and then a table with the same name is created usingCREATE TABLE
, using the PreparedStatement may result in no response from the server or cause the server to crash.Note
Workaround:
Recreate the PreparedStatement before using it to avoid this issue.
TSURUGI-IS-706 Executing widely ranged SELECT, UPDATE, or DELETE operations may prevent other requests.
Problem:
When executing large-scale
SELECT
,UPDATE
, orDELETE
operations on a table within an transaction, executing anINSERT
statement from another transaction on the same table may cause theINSERT
operation to be blocked until the former operations are completed.Note
Workaround:
As a feature under development, specifying
sql.scan_block_size
in the configuration filetsurugi.ini
may alleviate the blocking of scan operations.This parameter specifies the number of records to be processed in a single scan operation.
If the specified value is exceeded in a single scan operation, the scan process can be temporarily paused to allow other tasks to proceed.
Since this feature is under development, it may not function correctly at this time. Additionally, the specifications of the parameter may change in the future.
TSURUGI-IS-731 Searching with keys of a different type than the column definition may result in some incorrect results.
Problem:
Using keys of a different type than the column definition for searches can result in incorrect outcomes near the maximum or minimum values of the type.
Here is an example:
In the above example,
-2147483648
is included in the results even though it should not match the conditionc0=2147483648
.The expected query result is 0 rows.
TSURUGI-IS-732 Performing binary operations between DECIMAL and non-DECIMAL types may result in an error.
Problem:
When performing binary operations between
DECIMAL
and non-DECIMAL
types, the result may differ from the specification.According to the specification, comparison operations between
DECIMAL
andDOUBLE PRECISION
(float8
) should implicitly convert theDECIMAL
value toDOUBLE PRECISION
before comparison. However, the current implementation results in an error.TSURUGI-IS-891 Performing both INSERT and DELETE on the same row within the same transaction results in an inconsistent state.
Problem:
If the rows inserted in the transaction was deleted within the same transaction, the rows will unfortunately remain after the transaction may completed.
Note
Workaround:
Executing
DELETE
twice ensures that the record is properly deleted.TSURUGI-IS-897 The result of numerical operations wraps around.
Problem:
If the result of numeric operations exceeds the range of their types, it gets cycled through without an error.
TSURUGI-IS-933 Repeating certain syntax elements excessively in SQL can cause the database to become unstable.
Problem:
Repeating certain syntax elements excessively in SQL can cause the database to exhibit unstable behavior, including crashes.
The currently known examples are as follows:
IN
clause (e.g.,x IN (1, 2, 3, ...)
)OR
in a conditional expression (e.g.,x = 1 OR x = 2 OR x = 3 OR ...
)In simple cases, the compiler automatically detects these and then will report a compile error before the database becomes unstable.
However, in complex cases, the compiler may not detect them.
TSURUGI-IS-942 Cannot apply
ORDER BY
orLIMIT
to the entire query expression.Problem:
In SQL, the
ORDER BY
andLIMIT
clauses can be used to specify the order and number of elements in the query results. However, they cannot be applied to the entire query expression that includesUNION ALL
and similar constructs. Here is an example:The above is expected to retrieve all rows from tables
t1
andt2
and, return only upto one row from them. However, in the current implementation, it retrieves only 1 row fromt2
and returns the result of adding it to the contents oft1
. In other words, the total number of rows becomes (number of rows in t1
) + 1.Note
Workaround:
To get the expected results, retrieve the data in a table subquery, and then apply
ORDER BY
orLIMIT
to the outer query. Here is an example:TSURUGI-IS-945 Executing
COUNT(DISTINCT ...)
on a large dataset cause the database to become unstable.Problem:
Executing
SELECT COUNT(DISTINCT ...)
on a large dataset cause the database to become unstable, resulting in incorrect or no response.TSURUGI-IS-957 The results of the
MIN
andMAX
functions onCHAR
type may be incorrect.Problem:
When executing the aggregate functions
MIN
andMAX
on theCHAR
type, the expected behavior is to obtain the minimum and maximum values based on alphabetical order. However, depending on the size of theCHAR
type, the results of the aggregate functions may be incorrect.TSURUGI-IS-959 Including
COUNT(DISTINCT)
and other aggregate functions in a query may result in an error.Problem:
Including aggregate functions that operate on DISTINCT values, such as
COUNT(DISTINCT ...)
, and aggregate functions that calculate with duplicates, such asMAX
, in the sameSELECT
statement may result in an error.TSURUGI-IS-960
UNION ALL
andLIMIT
operations may perform inefficiently.Problem:
When concatenating multiple query results using
UNION ALL
, the process can be inefficient internally.Specifically, the SQL execution engine expands the operands of
UNION ALL
into memory and then concatenates them. This increases the amount of memory required to execute the query and can also slow down the overall response time.LIMIT
operations withoutORDER BY
clause have similar issues. For example, the SQL engine may scan whole the table even when trying to retrieve only one record withLIMIT 1
. However, unlikeUNION ALL
, not all records are expanded into memory, and those exceeding the specified number are discarded.TSURUGI-IS-139 Conditional expressions containing
OR
generate inefficient execution plans.Problem:
When a conditional expression contains
OR
, it may generate an inefficient execution plan.For example, executing the following SQL on a table
t
with a primary keykey
will generate an execution plan that performs a full table scan ont
.Additionally, currently, the
IN
clause is internally expanded toOR
, causing similar issues.Note
Workaround:
You can achieve the same result by connecting each condition term with
UNION (DISTINCT)
orUNION ALL
.TSURUGI-IS-681
MIN
andMAX
generate inefficient execution plans.Problem:
Even when specifying the aggregate functions
MAX
andMIN
for index key items, an execution plan involving a full scan is generated.Ideally, these cases should operate quickly by retrieving only one item from the beginning or end of the index, but currently, such optimizations are not implemented.
This also applies to
ORDER BY ... LIMIT ...
(so-calledTOP-N
queries).TSURUGI-IS-863 Cannot specify the join order in
JOIN
clauses.Problem:
When performing JOIN operations with three or more tables, the SQL standard allows specifying the join order using syntax like
t1 JOIN (t2 JOIN t3 ON ...) ON ...
. However, this syntax is not currently supported.Note
Workaround:
Instead, you can use subqueries to explicitly specify the join order.
Beta Was this translation helpful? Give feedback.
All reactions