When attempting to import a database dump from a MariaDB 10.5.15 to MariaDB 10.5.22 server, I encounter an error regarding a GENERATED ALWAYS AS / foreign key constraint in a table definition.
This is the error:
ERROR 1901 (HY000) at line 539: Function or expression 'food_id' cannot be used in the GENERATED ALWAYS AS clause of `open_ended`
The error seems to be related to the following change in 10.5.22: MDEV-18114 and I have checked that this error does not occur in MariaDB 10.5.21.
Here is the full statement that fails on 10.5.22 but works in previous releases:
CREATE TABLE `intakes` (
|
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
|
`dataset_id` bigint(20) unsigned NOT NULL,
|
`day_id` bigint(20) unsigned DEFAULT NULL,
|
`meal_id` bigint(20) unsigned DEFAULT NULL,
|
`group_id` bigint(20) unsigned DEFAULT NULL,
|
`food_id` bigint(20) unsigned DEFAULT NULL,
|
`code` bigint(20) unsigned NOT NULL,
|
`line` text COLLATE utf8mb4_unicode_ci DEFAULT NULL,
|
`quantity` text COLLATE utf8mb4_unicode_ci DEFAULT NULL,
|
`portions` tinyint(3) unsigned DEFAULT NULL,
|
`hash` char(40) GENERATED ALWAYS AS (case when `line` is not null then sha(lcase(trim(`line`))) else NULL end) STORED,
|
`open_ended` tinyint(1) GENERATED ALWAYS AS (case when `food_id` is null then 1 else 0 end) STORED,
|
`attributes` longtext CHARACTER SET utf8mb4 COLLATE utf8mb4_bin DEFAULT NULL CHECK (json_valid(`attributes`)),
|
`created_date` date GENERATED ALWAYS AS (cast(`created_at` as date)) STORED,
|
`created_at` timestamp NULL DEFAULT NULL,
|
`updated_at` timestamp NULL DEFAULT NULL,
|
PRIMARY KEY (`id`),
|
KEY `intakes_dataset_id_foreign` (`dataset_id`),
|
KEY `intakes_day_id_foreign` (`day_id`),
|
KEY `intakes_meal_id_foreign` (`meal_id`),
|
KEY `intakes_food_id_foreign` (`food_id`),
|
KEY `intakes_code_index` (`code`),
|
KEY `intakes_created_date_index` (`created_date`),
|
KEY `intakes_open_ended_index` (`open_ended`),
|
KEY `intakes_dataset_id_open_ended_index` (`dataset_id`,`open_ended`),
|
KEY `intakes_dataset_id_open_ended_created_date_index` (`dataset_id`,`open_ended`,`created_date`),
|
KEY `intakes_hash_index` (`hash`),
|
KEY `intakes_group_id_foreign` (`group_id`),
|
FULLTEXT KEY `intakes_line_fulltext` (`line`),
|
CONSTRAINT `intakes_dataset_id_foreign` FOREIGN KEY (`dataset_id`) REFERENCES `datasets` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
CONSTRAINT `intakes_day_id_foreign` FOREIGN KEY (`day_id`) REFERENCES `days` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
CONSTRAINT `intakes_food_id_foreign` FOREIGN KEY (`food_id`) REFERENCES `foods` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
CONSTRAINT `intakes_group_id_foreign` FOREIGN KEY (`group_id`) REFERENCES `groups` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
CONSTRAINT `intakes_meal_id_foreign` FOREIGN KEY (`meal_id`) REFERENCES `meals` (`id`) ON DELETE SET NULL ON UPDATE CASCADE
|
) ENGINE=InnoDB AUTO_INCREMENT=438584 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
|
{"report":{"fcp":3810.2999999523163,"ttfb":399.69999980926514,"pageVisibility":"visible","entityId":125969,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"81da4af6-181c-4cd6-9662-323d89573857","navigationType":0,"readyForUser":3971.2999999523163,"redirectCount":0,"resourceLoadedEnd":3486.399999856949,"resourceLoadedStart":408.39999985694885,"resourceTiming":[{"duration":128.79999995231628,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":408.39999985694885,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":408.39999985694885,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":537.1999998092651,"responseStart":0,"secureConnectionStart":0},{"duration":128.90000009536743,"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":408.69999980926514,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":408.69999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":537.5999999046326,"responseStart":0,"secureConnectionStart":0},{"duration":2700.5,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":408.89999985694885,"connectEnd":408.89999985694885,"connectStart":408.89999985694885,"domainLookupEnd":408.89999985694885,"domainLookupStart":408.89999985694885,"fetchStart":408.89999985694885,"redirectEnd":0,"redirectStart":0,"requestStart":541.0999999046326,"responseEnd":3109.399999856949,"responseStart":903.6999998092651,"secureConnectionStart":408.89999985694885},{"duration":3077.2999999523163,"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":409.09999990463257,"connectEnd":409.09999990463257,"connectStart":409.09999990463257,"domainLookupEnd":409.09999990463257,"domainLookupStart":409.09999990463257,"fetchStart":409.09999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":541.1999998092651,"responseEnd":3486.399999856949,"responseStart":962.0999999046326,"secureConnectionStart":409.09999990463257},{"duration":670.2999999523163,"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":409.2999999523163,"connectEnd":409.2999999523163,"connectStart":409.2999999523163,"domainLookupEnd":409.2999999523163,"domainLookupStart":409.2999999523163,"fetchStart":409.2999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":541.3999998569489,"responseEnd":1079.5999999046326,"responseStart":963.2999999523163,"secureConnectionStart":409.2999999523163},{"duration":670.5,"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":409.39999985694885,"connectEnd":409.39999985694885,"connectStart":409.39999985694885,"domainLookupEnd":409.39999985694885,"domainLookupStart":409.39999985694885,"fetchStart":409.39999985694885,"redirectEnd":0,"redirectStart":0,"requestStart":541.3999998569489,"responseEnd":1079.8999998569489,"responseStart":1019.7999999523163,"secureConnectionStart":409.39999985694885},{"duration":710.7000000476837,"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":409.69999980926514,"connectEnd":409.69999980926514,"connectStart":409.69999980926514,"domainLookupEnd":409.69999980926514,"domainLookupStart":409.69999980926514,"fetchStart":409.69999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":541.5999999046326,"responseEnd":1120.3999998569489,"responseStart":1081.0999999046326,"secureConnectionStart":409.69999980926514},{"duration":128.29999995231628,"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":409.7999999523163,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":409.7999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":538.0999999046326,"responseStart":0,"secureConnectionStart":0},{"duration":710.1999998092651,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":410,"connectEnd":410,"connectStart":410,"domainLookupEnd":410,"domainLookupStart":410,"fetchStart":410,"redirectEnd":0,"redirectStart":0,"requestStart":541.6999998092651,"responseEnd":1120.1999998092651,"responseStart":1080.1999998092651,"secureConnectionStart":410},{"duration":128.59999990463257,"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":410.2999999523163,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":410.2999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":538.8999998569489,"responseStart":0,"secureConnectionStart":0},{"duration":711.2999999523163,"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":410.5,"connectEnd":410.5,"connectStart":410.5,"domainLookupEnd":410.5,"domainLookupStart":410.5,"fetchStart":410.5,"redirectEnd":0,"redirectStart":0,"requestStart":541.7999999523163,"responseEnd":1121.7999999523163,"responseStart":1117.6999998092651,"secureConnectionStart":410.5},{"duration":3044.4000000953674,"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":414.39999985694885,"connectEnd":414.39999985694885,"connectStart":414.39999985694885,"domainLookupEnd":414.39999985694885,"domainLookupStart":414.39999985694885,"fetchStart":414.39999985694885,"redirectEnd":0,"redirectStart":0,"requestStart":669.3999998569489,"responseEnd":3458.7999999523163,"responseStart":3400.2999999523163,"secureConnectionStart":414.39999985694885},{"duration":3040,"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":419.2999999523163,"connectEnd":419.2999999523163,"connectStart":419.2999999523163,"domainLookupEnd":419.2999999523163,"domainLookupStart":419.2999999523163,"fetchStart":419.2999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":856.0999999046326,"responseEnd":3459.2999999523163,"responseStart":3451.2999999523163,"secureConnectionStart":419.2999999523163},{"duration":216.5,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":3343,"connectEnd":3343,"connectStart":3343,"domainLookupEnd":3343,"domainLookupStart":3343,"fetchStart":3343,"redirectEnd":0,"redirectStart":0,"requestStart":3343,"responseEnd":3559.5,"responseStart":3559.5,"secureConnectionStart":3343}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":136,"responseStart":399,"responseEnd":419,"domLoading":403,"domInteractive":4063,"domContentLoadedEventStart":4063,"domContentLoadedEventEnd":4131,"domComplete":4645,"loadEventStart":4645,"loadEventEnd":4646,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":4043},{"name":"bigPipe.sidebar-id.end","time":4044},{"name":"bigPipe.activity-panel-pipe-id.start","time":4044.0999999046326},{"name":"bigPipe.activity-panel-pipe-id.end","time":4045.0999999046326},{"name":"activityTabFullyLoaded","time":4163.5}],"measures":[],"correlationId":"a4c109b9ee8915","effectiveType":"4g","downlink":9.6,"rtt":0,"serverDuration":105,"dbReadsTimeInMs":15,"dbConnsTimeInMs":24,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
It is intentional. The way MariaDB works, and always did, foreign key cascading actions are applied to child tables on a very low level where the server cannot update STORED generated column values anymore. In other words, if a STORED generated column depends on a column that can be modified via a cascade action, this STORED column can become out of sync with other columns. Basically, it'll have an incorrect value. That's why such a table structure is no longer allowed.
We're planning to lift this restriction. MDEV-31942 (or MDEV-22361) when implemented, will allow us to recalculate STORED generated columns on UPDATE CASCADE and SET NULL actions.
Note that ON DELETE CASCADE is fine, it's allowed, because it doesn't modify individual columns, but deletes the complete row.
VIRTUAL columns are also fine.