MDEV-10134 introduced support for creating a table whose default is an expression.
SHOW [FULL] COLUMNS/FIELDS and INFORMATION_SCHEMA.COLUMNS show these default expressions, but because these just look like strings, it seems to be impossible for a client program to tell if the default is an expression or a literal string.
For example:
MariaDB [test]> create table testtbl (cts varchar(255) default current_timestamp, sts varchar(255) default 'current_timestamp()'); show columns from testtbl; select * from information_schema.columns where table_name='testtbl';
|
Query OK, 0 rows affected (0.13 sec)
|
|
+-------+--------------+------+-----+---------------------+-------+
|
| Field | Type | Null | Key | Default | Extra |
|
+-------+--------------+------+-----+---------------------+-------+
|
| cts | varchar(255) | YES | | current_timestamp() | |
|
| sts | varchar(255) | YES | | current_timestamp() | |
|
+-------+--------------+------+-----+---------------------+-------+
|
2 rows in set (0.00 sec)
|
|
+---------------+--------------+------------+-------------+------------------+---------------------+-------------+-----------+--------------------------+------------------------+-------------------+---------------+--------------------+--------------------+-------------------+--------------+------------+-------+---------------------------------+----------------+--------------+-----------------------+
|
| TABLE_CATALOG | TABLE_SCHEMA | TABLE_NAME | COLUMN_NAME | ORDINAL_POSITION | COLUMN_DEFAULT | IS_NULLABLE | DATA_TYPE | CHARACTER_MAXIMUM_LENGTH | CHARACTER_OCTET_LENGTH | NUMERIC_PRECISION | NUMERIC_SCALE | DATETIME_PRECISION | CHARACTER_SET_NAME | COLLATION_NAME | COLUMN_TYPE | COLUMN_KEY | EXTRA | PRIVILEGES | COLUMN_COMMENT | IS_GENERATED | GENERATION_EXPRESSION |
|
+---------------+--------------+------------+-------------+------------------+---------------------+-------------+-----------+--------------------------+------------------------+-------------------+---------------+--------------------+--------------------+-------------------+--------------+------------+-------+---------------------------------+----------------+--------------+-----------------------+
|
| def | test | testtbl | cts | 1 | current_timestamp() | YES | varchar | 255 | 255 | NULL | NULL | NULL | latin1 | latin1_swedish_ci | varchar(255) | | | select,insert,update,references | | NEVER | NULL |
|
| def | test | testtbl | sts | 2 | current_timestamp() | YES | varchar | 255 | 255 | NULL | NULL | NULL | latin1 | latin1_swedish_ci | varchar(255) | | | select,insert,update,references | | NEVER | NULL |
|
+---------------+--------------+------------+-------------+------------------+---------------------+-------------+-----------+--------------------------+------------------------+-------------------+---------------+--------------------+--------------------+-------------------+--------------+------------+-------+---------------------------------+----------------+--------------+-----------------------+
|
2 rows in set (0.00 sec)
|
This makes it hard to dump and restore the schema properly in database utilities (eg. my Kitchen Sync).
Note that the server does know (SHOW CREATE TABLE has quotes for the sts DEFAULT but not for the cts DEFAULT), but frameworks would have to parse this instead of using the SHOW statements or INFORMATION_SCHEMA views provided for giving the other table/column metadata.
{"report":{"fcp":1398.7999997138977,"ttfb":436.7999997138977,"pageVisibility":"visible","entityId":61863,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"7d0f5bb2-58a8-42a8-a546-3ab327a45778","navigationType":0,"readyForUser":1583.7999997138977,"redirectCount":0,"resourceLoadedEnd":1389.9000000953674,"resourceLoadedStart":443.7999997138977,"resourceTiming":[{"duration":439.2000002861023,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":443.7999997138977,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":443.7999997138977,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":883,"responseStart":0,"secureConnectionStart":0},{"duration":439.30000019073486,"initiatorType":"link","name":"https://jira.mariadb.org/s/7ebd35e77e471bc30ff0eba799ebc151-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/css/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":444.09999990463257,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":444.09999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":883.4000000953674,"responseStart":0,"secureConnectionStart":0},{"duration":448,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":444.2999997138977,"connectEnd":444.2999997138977,"connectStart":444.2999997138977,"domainLookupEnd":444.2999997138977,"domainLookupStart":444.2999997138977,"fetchStart":444.2999997138977,"redirectEnd":0,"redirectStart":0,"requestStart":444.2999997138977,"responseEnd":892.2999997138977,"responseStart":892.2999997138977,"secureConnectionStart":444.2999997138977},{"duration":590.9000000953674,"initiatorType":"script","name":"https://jira.mariadb.org/s/2d8175ec2fa4c816e8023260bd8c1786-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/js/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&locale=en&slack-enabled=true&whisper-enabled=true","startTime":444.5,"connectEnd":444.5,"connectStart":444.5,"domainLookupEnd":444.5,"domainLookupStart":444.5,"fetchStart":444.5,"redirectEnd":0,"redirectStart":0,"requestStart":444.5,"responseEnd":1035.4000000953674,"responseStart":1035.4000000953674,"secureConnectionStart":444.5},{"duration":594.5,"initiatorType":"script","name":"https://jira.mariadb.org/s/a9324d6758d385eb45c462685ad88f1d-CDN/lu2cib/820016/12ta74/c92c0caa9a024ae85b0ebdbed7fb4bd7/_/download/contextbatch/js/atl.global,-_super/batch.js?locale=en","startTime":444.7999997138977,"connectEnd":444.7999997138977,"connectStart":444.7999997138977,"domainLookupEnd":444.7999997138977,"domainLookupStart":444.7999997138977,"fetchStart":444.7999997138977,"redirectEnd":0,"redirectStart":0,"requestStart":444.7999997138977,"responseEnd":1039.2999997138977,"responseStart":1039.2999997138977,"secureConnectionStart":444.7999997138977},{"duration":594.6999998092651,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-en/jira.webresources:calendar-en.js","startTime":445,"connectEnd":445,"connectStart":445,"domainLookupEnd":445,"domainLookupStart":445,"fetchStart":445,"redirectEnd":0,"redirectStart":0,"requestStart":445,"responseEnd":1039.6999998092651,"responseStart":1039.6999998092651,"secureConnectionStart":445},{"duration":594.8000001907349,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-localisation-moment/jira.webresources:calendar-localisation-moment.js","startTime":445.19999980926514,"connectEnd":445.19999980926514,"connectStart":445.19999980926514,"domainLookupEnd":445.19999980926514,"domainLookupStart":445.19999980926514,"fetchStart":445.19999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":445.19999980926514,"responseEnd":1040,"responseStart":1040,"secureConnectionStart":445.19999980926514},{"duration":608.6000003814697,"initiatorType":"link","name":"https://jira.mariadb.org/s/b04b06a02d1959df322d9cded3aeecc1-CDN/lu2cib/820016/12ta74/a2ff6aa845ffc9a1d22fe23d9ee791fc/_/download/contextbatch/css/jira.global.look-and-feel,-_super/batch.css","startTime":445.2999997138977,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":445.2999997138977,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1053.9000000953674,"responseStart":0,"secureConnectionStart":0},{"duration":595,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":445.5,"connectEnd":445.5,"connectStart":445.5,"domainLookupEnd":445.5,"domainLookupStart":445.5,"fetchStart":445.5,"redirectEnd":0,"redirectStart":0,"requestStart":445.5,"responseEnd":1040.5,"responseStart":1040.5,"secureConnectionStart":445.5},{"duration":608.3000001907349,"initiatorType":"link","name":"https://jira.mariadb.org/s/3ac36323ba5e4eb0af2aa7ac7211b4bb-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/css/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.css?jira.create.linked.issue=true","startTime":445.59999990463257,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":445.59999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1053.9000000953674,"responseStart":0,"secureConnectionStart":0},{"duration":595.5,"initiatorType":"script","name":"https://jira.mariadb.org/s/5d5e8fe91fbc506585e83ea3b62ccc4b-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/js/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.js?jira.create.linked.issue=true&locale=en","startTime":445.7999997138977,"connectEnd":445.7999997138977,"connectStart":445.7999997138977,"domainLookupEnd":445.7999997138977,"domainLookupStart":445.7999997138977,"fetchStart":445.7999997138977,"redirectEnd":0,"redirectStart":0,"requestStart":445.7999997138977,"responseEnd":1041.2999997138977,"responseStart":1041.2999997138977,"secureConnectionStart":445.7999997138977},{"duration":900.9000000953674,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-js/jira.webresources:bigpipe-js.js","startTime":447,"connectEnd":447,"connectStart":447,"domainLookupEnd":447,"domainLookupStart":447,"fetchStart":447,"redirectEnd":0,"redirectStart":0,"requestStart":447,"responseEnd":1347.9000000953674,"responseStart":1347.9000000953674,"secureConnectionStart":447},{"duration":938.7000002861023,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-init/jira.webresources:bigpipe-init.js","startTime":451.19999980926514,"connectEnd":451.19999980926514,"connectStart":451.19999980926514,"domainLookupEnd":451.19999980926514,"domainLookupStart":451.19999980926514,"fetchStart":451.19999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":451.19999980926514,"responseEnd":1389.9000000953674,"responseStart":1389.9000000953674,"secureConnectionStart":451.19999980926514},{"duration":288.40000009536743,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1060,"connectEnd":1060,"connectStart":1060,"domainLookupEnd":1060,"domainLookupStart":1060,"fetchStart":1060,"redirectEnd":0,"redirectStart":0,"requestStart":1060,"responseEnd":1348.4000000953674,"responseStart":1348.4000000953674,"secureConnectionStart":1060},{"duration":276.7999997138977,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":1389.4000000953674,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1389.4000000953674,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1666.1999998092651,"responseStart":0,"secureConnectionStart":0}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":266,"responseStart":437,"responseEnd":442,"domLoading":441,"domInteractive":1732,"domContentLoadedEventStart":1733,"domContentLoadedEventEnd":1786,"domComplete":2682,"loadEventStart":2682,"loadEventEnd":2682,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1686.2999997138977},{"name":"bigPipe.sidebar-id.end","time":1687.1999998092651},{"name":"bigPipe.activity-panel-pipe-id.start","time":1687.2999997138977},{"name":"bigPipe.activity-panel-pipe-id.end","time":1689},{"name":"activityTabFullyLoaded","time":1806.0999999046326}],"measures":[],"correlationId":"4869283825497e","effectiveType":"4g","downlink":9.9,"rtt":0,"serverDuration":106,"dbReadsTimeInMs":14,"dbConnsTimeInMs":24,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
Right. It looks like we've misunderstood the standard when INFORMATION_SCHEMA.COLUMNS was originally implemented. If yes, this is certainly a bug that should be fixed.