Type:
Bug
Priority:
Major
Resolution:
Fixed
Affects Version/s:
5.5(EOL) , 10.0(EOL) , 10.1(EOL) , 10.2(EOL) , 10.3(EOL)
In InnoDB, an INSERT will not create an explicit lock object. Instead, the inserted record is initially implicitly locked by the transaction that wrote its trx_t::id to the hidden system column DB_TRX_ID . (Other transactions would check if DB_TRX_ID is referring to a transaction that has not been committed.)
If a record was inserted in the current transaction, it would be implicitly locked by that transaction. Only if some other transaction is requesting access to the record, the implicit lock should be converted to an explicit one, so that the waits-for graph can be constructed for detecting deadlocks and lock wait timeouts.
The bug is that currently, InnoDB would convert the implicit lock to an explicit one, even if no conflict exists. Here is an example:
--source include/have_innodb.inc
CREATE TABLE t1(id INT PRIMARY KEY , a INT , b CHAR (1), UNIQUE KEY u(a,b)) ENGINE=InnoDB;
BEGIN ;
INSERT INTO t1 VALUES (1,1, 'a' ),(2,9999, 'b' ),(3,10000, 'c' ),(4,4, 'd' );
DELETE FROM t1 WHERE a = 9999 AND b= 'b' ;
COMMIT ;
DROP TABLE t1;
In this test, there is no conflict, and the DELETE statement should not convert the implicit lock into an explicit one. But, the function lock_rec_convert_impl_to_expl_for_trx() is being invoked during the test.
Marko Mäkelä
made changes -
2018-07-03 11:02
Status
Open
[ 1
]
In Progress
[ 3
]
Marko Mäkelä
made changes -
2018-07-03 12:20
Assignee
Marko Mäkelä
[ marko
]
Thirunarayanan B
[ thiru
]
Status
In Progress
[ 3
]
In Review
[ 10002
]
Status
In Review
[ 10002
]
Stalled
[ 10000
]
Marko Mäkelä
made changes -
2018-07-04 13:13
Fix Version/s
10.3.9
[ 23114
]
Fix Version/s
10.3
[ 22126
]
Assignee
Thirunarayanan B
[ thiru
]
Marko Mäkelä
[ marko
]
Resolution
Fixed
[ 1
]
Status
Stalled
[ 10000
]
Closed
[ 6
]
Sergei Golubchik
made changes -
2021-12-06 21:47
Workflow
MariaDB v3
[ 88204
]
MariaDB v4
[ 154619
]
{"report":{"fcp":1162.3999996185303,"ttfb":407.30000019073486,"pageVisibility":"visible","entityId":68494,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":32,"apdex":0.5,"journeyId":"0b72aecf-2c3e-44d8-8bd1-ea97c430a8d1","navigationType":0,"readyForUser":1237.8999996185303,"redirectCount":0,"resourceLoadedEnd":795.1000003814697,"resourceLoadedStart":413.19999980926514,"resourceTiming":[{"duration":100.5,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":413.19999980926514,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":413.19999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":513.6999998092651,"responseStart":0,"secureConnectionStart":0},{"duration":100.89999961853027,"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":413.5,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":413.5,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":514.3999996185303,"responseStart":0,"secureConnectionStart":0},{"duration":306.5999994277954,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":413.6000003814697,"connectEnd":413.6000003814697,"connectStart":413.6000003814697,"domainLookupEnd":413.6000003814697,"domainLookupStart":413.6000003814697,"fetchStart":413.6000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":519.1999998092651,"responseEnd":720.1999998092651,"responseStart":535.1999998092651,"secureConnectionStart":413.6000003814697},{"duration":368.8999996185303,"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":413.80000019073486,"connectEnd":413.80000019073486,"connectStart":413.80000019073486,"domainLookupEnd":413.80000019073486,"domainLookupStart":413.80000019073486,"fetchStart":413.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":519.6999998092651,"responseEnd":782.6999998092651,"responseStart":547.1999998092651,"secureConnectionStart":413.80000019073486},{"duration":126.19999980926514,"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":414,"connectEnd":414,"connectStart":414,"domainLookupEnd":414,"domainLookupStart":414,"fetchStart":414,"redirectEnd":0,"redirectStart":0,"requestStart":521.1000003814697,"responseEnd":540.1999998092651,"responseStart":538.1000003814697,"secureConnectionStart":414},{"duration":126.39999961853027,"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":414.1000003814697,"connectEnd":414.1000003814697,"connectStart":414.1000003814697,"domainLookupEnd":414.1000003814697,"domainLookupStart":414.1000003814697,"fetchStart":414.1000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":521.5,"responseEnd":540.5,"responseStart":539,"secureConnectionStart":414.1000003814697},{"duration":130.69999980926514,"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":414.30000019073486,"connectEnd":414.30000019073486,"connectStart":414.30000019073486,"domainLookupEnd":414.30000019073486,"domainLookupStart":414.30000019073486,"fetchStart":414.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":522,"responseEnd":545,"responseStart":542.1000003814697,"secureConnectionStart":414.30000019073486},{"duration":104.39999961853027,"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":414.5,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":414.5,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":518.8999996185303,"responseStart":0,"secureConnectionStart":0},{"duration":130.89999961853027,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":414.6000003814697,"connectEnd":414.6000003814697,"connectStart":414.6000003814697,"domainLookupEnd":414.6000003814697,"domainLookupStart":414.6000003814697,"fetchStart":414.6000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":524.8000001907349,"responseEnd":545.5,"responseStart":542.8999996185303,"secureConnectionStart":414.6000003814697},{"duration":105.59999942779541,"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":414.80000019073486,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":414.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":520.3999996185303,"responseStart":0,"secureConnectionStart":0},{"duration":133.80000019073486,"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":414.8999996185303,"connectEnd":414.8999996185303,"connectStart":414.8999996185303,"domainLookupEnd":414.8999996185303,"domainLookupStart":414.8999996185303,"fetchStart":414.8999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":525.5,"responseEnd":548.6999998092651,"responseStart":546.5,"secureConnectionStart":414.8999996185303},{"duration":374.6000003814697,"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":416.19999980926514,"connectEnd":416.19999980926514,"connectStart":416.19999980926514,"domainLookupEnd":416.19999980926514,"domainLookupStart":416.19999980926514,"fetchStart":416.19999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":603.3999996185303,"responseEnd":790.8000001907349,"responseStart":785.8999996185303,"secureConnectionStart":416.19999980926514},{"duration":378.80000019073486,"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":416.30000019073486,"connectEnd":416.30000019073486,"connectStart":416.30000019073486,"domainLookupEnd":416.30000019073486,"domainLookupStart":416.30000019073486,"fetchStart":416.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":656.6000003814697,"responseEnd":795.1000003814697,"responseStart":789,"secureConnectionStart":416.30000019073486},{"duration":206.69999980926514,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":910,"connectEnd":910,"connectStart":910,"domainLookupEnd":910,"domainLookupStart":910,"fetchStart":910,"redirectEnd":0,"redirectStart":0,"requestStart":1080,"responseEnd":1116.6999998092651,"responseStart":1114.5,"secureConnectionStart":910}],"fetchStart":1,"domainLookupStart":1,"domainLookupEnd":1,"connectStart":1,"connectEnd":1,"requestStart":168,"responseStart":408,"responseEnd":411,"domLoading":411,"domInteractive":1307,"domContentLoadedEventStart":1307,"domContentLoadedEventEnd":1353,"domComplete":3093,"loadEventStart":3093,"loadEventEnd":3093,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1276.8999996185303},{"name":"bigPipe.sidebar-id.end","time":1277.6999998092651},{"name":"bigPipe.activity-panel-pipe-id.start","time":1277.8000001907349},{"name":"bigPipe.activity-panel-pipe-id.end","time":1281},{"name":"activityTabFullyLoaded","time":1377.3000001907349}],"measures":[],"correlationId":"e53c2bff3063a2","effectiveType":"4g","downlink":10,"rtt":0,"serverDuration":159,"dbReadsTimeInMs":31,"dbConnsTimeInMs":44,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}