MySQL 5.6 (and MariaDB 10.0) introduced online ADD INDEX, that is, creating a secondary index while the table is being modified. (It also introduced online table rebuild for cases like adding or dropping columns.)
MariaDB could extend this and support background ADD INDEX, that is, submit a request an index to be created, and do not care when it completes. Technically, the index would exist in the data dictionary, but queries would have to avoid using the index until the storage engine confirms that it is usable.
We cannot support ADD UNIQUE INDEX in the background, because the ability to flag duplicate key errors requires the index to exist. If concurrent INSERT or UPDATE opreations would introduce duplicate keys, that will have to result in the failure of the ADD UNIQUE INDEX operation.
Implementing this feature should require a new storage engine handler call for checking whether an index is usable, and some change of the InnoDB persistent data dictionary. Preferrably, I would first eliminate the InnoDB dictionary tables, such as SYS_INDEXES, and store the secondary index root page numbers and some status information within the .ibd file. This would allow crash-safe operation. (In case the server is killed before the index creation completes, on server restart the index creation would have to start from the beginning, possibly after an explicit statement to request it.)
Attachments
Issue Links
relates to
MDEV-16264Implement a common work queue for InnoDB background tasks
Closed
MDEV-16281Implement parallel CREATE INDEX, ALTER TABLE, or bulk load
If there is no practical demand for a feature that is by design incompatible with transactions, we should rather not do it at all.
Marko Mäkelä
added a comment - If there is no practical demand for a feature that is by design incompatible with transactions, we should rather not do it at all.
A thought... Can ADD UNIQUE INDEX be performed in 2 steps?
1. ADD INDEX (in background)
2. Convert INDEX to UNIQUE INDEX
Would this speed up ADD UNIQUE enough to be worth doing?
Rick James
added a comment - A thought... Can ADD UNIQUE INDEX be performed in 2 steps?
1. ADD INDEX (in background)
2. Convert INDEX to UNIQUE INDEX
Would this speed up ADD UNIQUE enough to be worth doing?
The point of UNIQUE index is to maintain uniqueness. If it wasn't done when the index was built, the fastest was to check it is to rebuild the index.
The problem is not building index in the background. This is easy to do, just open a new connection and do your ALTER TABLE there, from other connections' point of view it'll be "in the background". Or do it with CREATE EVENT.
The problem is that it doesn't make a logical sense to add a constraint that starts working in some unspecified point in time in the future.
Sergei Golubchik
added a comment - The point of UNIQUE index is to maintain uniqueness. If it wasn't done when the index was built, the fastest was to check it is to rebuild the index.
The problem is not building index in the background. This is easy to do, just open a new connection and do your ALTER TABLE there, from other connections' point of view it'll be "in the background". Or do it with CREATE EVENT.
The problem is that it doesn't make a logical sense to add a constraint that starts working in some unspecified point in time in the future .
People
Marko Mäkelä
Marko Mäkelä
Votes:
4Vote for this issue
Watchers:
8Start watching this issue
Dates
Created:
Updated:
Resolved:
Git Integration
Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.
{"report":{"fcp":940.9000000953674,"ttfb":211.5,"pageVisibility":"visible","entityId":67650,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"44b0d3dd-3d47-4f98-8e25-bd733843520b","navigationType":0,"readyForUser":1016,"redirectCount":0,"resourceLoadedEnd":634.0999999046326,"resourceLoadedStart":221.70000004768372,"resourceTiming":[{"duration":56.5,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":221.70000004768372,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":221.70000004768372,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":278.2000000476837,"responseStart":0,"secureConnectionStart":0},{"duration":56.5,"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":222.09999990463257,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":222.09999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":278.59999990463257,"responseStart":0,"secureConnectionStart":0},{"duration":252.60000014305115,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":222.29999995231628,"connectEnd":222.29999995231628,"connectStart":222.29999995231628,"domainLookupEnd":222.29999995231628,"domainLookupStart":222.29999995231628,"fetchStart":222.29999995231628,"redirectEnd":0,"redirectStart":0,"requestStart":281.09999990463257,"responseEnd":474.90000009536743,"responseStart":294,"secureConnectionStart":222.29999995231628},{"duration":397,"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":222.40000009536743,"connectEnd":222.40000009536743,"connectStart":222.40000009536743,"domainLookupEnd":222.40000009536743,"domainLookupStart":222.40000009536743,"fetchStart":222.40000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":282.09999990463257,"responseEnd":619.4000000953674,"responseStart":322.09999990463257,"secureConnectionStart":222.40000009536743},{"duration":79.70000004768372,"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":222.59999990463257,"connectEnd":222.59999990463257,"connectStart":222.59999990463257,"domainLookupEnd":222.59999990463257,"domainLookupStart":222.59999990463257,"fetchStart":222.59999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":284.09999990463257,"responseEnd":302.2999999523163,"responseStart":299.7999999523163,"secureConnectionStart":222.59999990463257},{"duration":76.90000009536743,"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":222.79999995231628,"connectEnd":222.79999995231628,"connectStart":222.79999995231628,"domainLookupEnd":222.79999995231628,"domainLookupStart":222.79999995231628,"fetchStart":222.79999995231628,"redirectEnd":0,"redirectStart":0,"requestStart":283.59999990463257,"responseEnd":299.7000000476837,"responseStart":298.40000009536743,"secureConnectionStart":222.79999995231628},{"duration":79.79999995231628,"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":222.90000009536743,"connectEnd":222.90000009536743,"connectStart":222.90000009536743,"domainLookupEnd":222.90000009536743,"domainLookupStart":222.90000009536743,"fetchStart":222.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":285.59999990463257,"responseEnd":302.7000000476837,"responseStart":300.7000000476837,"secureConnectionStart":222.90000009536743},{"duration":60.700000047683716,"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":223.20000004768372,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":223.20000004768372,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":283.90000009536743,"responseStart":0,"secureConnectionStart":0},{"duration":81.60000014305115,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":223.29999995231628,"connectEnd":223.29999995231628,"connectStart":223.29999995231628,"domainLookupEnd":223.29999995231628,"domainLookupStart":223.29999995231628,"fetchStart":223.29999995231628,"redirectEnd":0,"redirectStart":0,"requestStart":287.5,"responseEnd":304.90000009536743,"responseStart":302.90000009536743,"secureConnectionStart":223.29999995231628},{"duration":62.09999990463257,"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":223.5,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":223.5,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":285.59999990463257,"responseStart":0,"secureConnectionStart":0},{"duration":83.59999990463257,"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":223.70000004768372,"connectEnd":223.70000004768372,"connectStart":223.70000004768372,"domainLookupEnd":223.70000004768372,"domainLookupStart":223.70000004768372,"fetchStart":223.70000004768372,"redirectEnd":0,"redirectStart":0,"requestStart":289.90000009536743,"responseEnd":307.2999999523163,"responseStart":303.59999990463257,"secureConnectionStart":223.70000004768372},{"duration":405.7000000476837,"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":227.29999995231628,"connectEnd":227.29999995231628,"connectStart":227.29999995231628,"domainLookupEnd":227.29999995231628,"domainLookupStart":227.29999995231628,"fetchStart":227.29999995231628,"redirectEnd":0,"redirectStart":0,"requestStart":375.7999999523163,"responseEnd":633,"responseStart":624.0999999046326,"secureConnectionStart":227.29999995231628},{"duration":406.59999990463257,"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":227.5,"connectEnd":227.5,"connectStart":227.5,"domainLookupEnd":227.5,"domainLookupStart":227.5,"fetchStart":227.5,"redirectEnd":0,"redirectStart":0,"requestStart":441.7000000476837,"responseEnd":634.0999999046326,"responseStart":627,"secureConnectionStart":227.5},{"duration":107.39999985694885,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":619.7000000476837,"connectEnd":619.7000000476837,"connectStart":619.7000000476837,"domainLookupEnd":619.7000000476837,"domainLookupStart":619.7000000476837,"fetchStart":619.7000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":692.5999999046326,"responseEnd":727.0999999046326,"responseStart":726.2999999523163,"secureConnectionStart":619.7000000476837}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":45,"responseStart":212,"responseEnd":225,"domLoading":215,"domInteractive":1087,"domContentLoadedEventStart":1087,"domContentLoadedEventEnd":1141,"domComplete":1989,"loadEventStart":1989,"loadEventEnd":1990,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1064.5},{"name":"bigPipe.sidebar-id.end","time":1065.2999999523163},{"name":"bigPipe.activity-panel-pipe-id.start","time":1065.5},{"name":"bigPipe.activity-panel-pipe-id.end","time":1066.7999999523163},{"name":"activityTabFullyLoaded","time":1169.9000000953674}],"measures":[],"correlationId":"ad151540131a3b","effectiveType":"4g","downlink":9.5,"rtt":0,"serverDuration":96,"dbReadsTimeInMs":13,"dbConnsTimeInMs":22,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
It might be best to implement this after MDEV-16281 (parallel ADD INDEX) or
MDEV-16264(pool of background threads).