Details
-
Bug
-
Status: Closed (View Workflow)
-
Major
-
Resolution: Fixed
-
10.0(EOL), 10.1(EOL), 10.2(EOL), 10.3(EOL), 10.4(EOL), 10.5
-
None
Description
MDB limits DECIMAL column precision to 16 doing CTAS with floor/ceil over DECIMAL(X,Y) where X > 16.
Consider the example.
MariaDB [test]> CREATE TABLE `t44` (`d1` decimal(38,0) DEFAULT NULL);
|
ERROR 1050 (42S01): Table 't44' already exists
|
MariaDB [test]> drop table t44;
|
Query OK, 0 rows affected (0.008 sec)
|
|
MariaDB [test]> CREATE TABLE `t44` (`d1` decimal(38,0) DEFAULT NULL);
|
Query OK, 0 rows affected (0.014 sec)
|
|
MariaDB [test]> create table t45 as select floor(d1) from t44;
|
Query OK, 0 rows affected (0.017 sec)
|
Records: 0 Duplicates: 0 Warnings: 0
|
|
MariaDB [test]> show create table t45;
|
+-------+------------------------------------------------------------------------------------------------------+
|
| Table | Create Table |
|
+-------+------------------------------------------------------------------------------------------------------+
|
| t45 | CREATE TABLE `t45` (
|
`floor(d1)` decimal(16,0) DEFAULT NULL
|
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
|
+-------+------------------------------------------------------------------------------------------------------+
|
1 row in set (0.001 sec)
|
|
MariaDB [test]> insert into t44 values (12345678901234567890123456789012345678);
|
Query OK, 1 row affected (0.006 sec)
|
|
MariaDB [test]> select floor(d1) from t44;
|
+----------------------------------------+
|
| floor(d1) |
|
+----------------------------------------+
|
| 12345678901234567890123456789012345678 |
|
+----------------------------------------+
|
1 row in set (0.002 sec)
|
|
MariaDB [test]> drop table t45;
|
Query OK, 0 rows affected (0.009 sec)
|
|
MariaDB [test]> create table t45 as select floor(d1) from t44;
|
ERROR 1264 (22003): Out of range value for column 'floor(d1)' at row 1
|
Attachments
Issue Links
- relates to
-
MCOL-641 Full DECIMAL support in ColumnStore
- Closed