Type:
Task
Priority:
Minor
Resolution:
Fixed
Affects Version/s:
1.1.8
Environment:
Long network delay between client and server.
Sprint:
Sprint connector/j 1.3.0
CONJ-99 introduced support for the rewriteBatchedStatements=true JDBC URL parameter. This rewrites batched prepared statements into a single statement, when using PreparedStatement.addBatch() & executeBatch().
This works fine for INSERT statements which do not specify an ON DUPLICATE KEY UPDATE clause. However for statements which do, the generated SQL cannot be parsed because the ON DUPLICATE ... clause is repeated for each set of values. E.g. for a prepared statement such as:
prep.sql
INSERT INTO my_table (pkey, col1) VALUES (?, ?) ON DUPLICATE KEY UPDATE col1 = VALUES(col1)
after setting the parameters multiple times and calling addBatch() then executeBatch(), the generated SQL looks like this:
gen.sql
INSERT INTO my_table (pkey, col1) VALUES (1, 'a') ON DUPLICATE KEY UPDATE col1 = VALUES(col1),(2,'b') ON DUPLICATE KEY UPDATE col1 = VALUES(col1), ...
I've written a small patch with a test case to duplicate the issue, along with a suggested fix. The test will fail against 1.1.8 but should pass with the suggested fix.
{"report":{"fcp":1113.3999999761581,"ttfb":319.69999998807907,"pageVisibility":"visible","entityId":50225,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"a4ad4216-c9f3-4fc7-8038-d06bd0eb29e0","navigationType":0,"readyForUser":1202,"redirectCount":0,"resourceLoadedEnd":826.3999999761581,"resourceLoadedStart":324.89999997615814,"resourceTiming":[{"duration":199.20000004768372,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2bu7/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":324.89999997615814,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":324.89999997615814,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":524.1000000238419,"responseStart":0,"secureConnectionStart":0},{"duration":199.30000001192093,"initiatorType":"link","name":"https://jira.mariadb.org/s/7ebd35e77e471bc30ff0eba799ebc151-CDN/lu2bu7/820016/12ta74/8679b4946efa1a0bb029a3a22206fb5d/_/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","startTime":325.19999998807907,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":325.19999998807907,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":524.5,"responseStart":0,"secureConnectionStart":0},{"duration":386,"initiatorType":"script","name":"https://jira.mariadb.org/s/fbf975c0cce4b1abf04784eeae9ba1f4-CDN/lu2bu7/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":325.39999997615814,"connectEnd":325.39999997615814,"connectStart":325.39999997615814,"domainLookupEnd":325.39999997615814,"domainLookupStart":325.39999997615814,"fetchStart":325.39999997615814,"redirectEnd":0,"redirectStart":0,"requestStart":525.8000000119209,"responseEnd":711.3999999761581,"responseStart":543.8000000119209,"secureConnectionStart":325.39999997615814},{"duration":500.10000002384186,"initiatorType":"script","name":"https://jira.mariadb.org/s/099b33461394b8015fc36c0a4b96e19f-CDN/lu2bu7/820016/12ta74/8679b4946efa1a0bb029a3a22206fb5d/_/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","startTime":325.5,"connectEnd":325.5,"connectStart":325.5,"domainLookupEnd":325.5,"domainLookupStart":325.5,"fetchStart":325.5,"redirectEnd":0,"redirectStart":0,"requestStart":526.6000000238419,"responseEnd":825.6000000238419,"responseStart":559.6999999880791,"secureConnectionStart":325.5},{"duration":220.60000002384186,"initiatorType":"script","name":"https://jira.mariadb.org/s/94c15bff32baef80f4096a08aceae8bc-CDN/lu2bu7/820016/12ta74/c92c0caa9a024ae85b0ebdbed7fb4bd7/_/download/contextbatch/js/atl.global,-_super/batch.js?locale=en","startTime":325.69999998807907,"connectEnd":325.69999998807907,"connectStart":325.69999998807907,"domainLookupEnd":325.69999998807907,"domainLookupStart":325.69999998807907,"fetchStart":325.69999998807907,"redirectEnd":0,"redirectStart":0,"requestStart":527.6000000238419,"responseEnd":546.3000000119209,"responseStart":544.3000000119209,"secureConnectionStart":325.69999998807907},{"duration":226.4000000357628,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2bu7/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-en/jira.webresources:calendar-en.js","startTime":325.89999997615814,"connectEnd":325.89999997615814,"connectStart":325.89999997615814,"domainLookupEnd":325.89999997615814,"domainLookupStart":325.89999997615814,"fetchStart":325.89999997615814,"redirectEnd":0,"redirectStart":0,"requestStart":531.1999999880791,"responseEnd":552.3000000119209,"responseStart":551.1999999880791,"secureConnectionStart":325.89999997615814},{"duration":236.79999995231628,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2bu7/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-localisation-moment/jira.webresources:calendar-localisation-moment.js","startTime":326.10000002384186,"connectEnd":326.10000002384186,"connectStart":326.10000002384186,"domainLookupEnd":326.10000002384186,"domainLookupStart":326.10000002384186,"fetchStart":326.10000002384186,"redirectEnd":0,"redirectStart":0,"requestStart":537.5,"responseEnd":562.8999999761581,"responseStart":560.3999999761581,"secureConnectionStart":326.10000002384186},{"duration":209.9000000357628,"initiatorType":"link","name":"https://jira.mariadb.org/s/b04b06a02d1959df322d9cded3aeecc1-CDN/lu2bu7/820016/12ta74/a2ff6aa845ffc9a1d22fe23d9ee791fc/_/download/contextbatch/css/jira.global.look-and-feel,-_super/batch.css","startTime":326.19999998807907,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":326.19999998807907,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":536.1000000238419,"responseStart":0,"secureConnectionStart":0},{"duration":236.60000002384186,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":326.39999997615814,"connectEnd":326.39999997615814,"connectStart":326.39999997615814,"domainLookupEnd":326.39999997615814,"domainLookupStart":326.39999997615814,"fetchStart":326.39999997615814,"redirectEnd":0,"redirectStart":0,"requestStart":538.1999999880791,"responseEnd":563,"responseStart":561.1000000238419,"secureConnectionStart":326.39999997615814},{"duration":207.19999998807907,"initiatorType":"link","name":"https://jira.mariadb.org/s/3ac36323ba5e4eb0af2aa7ac7211b4bb-CDN/lu2bu7/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":331.19999998807907,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":331.19999998807907,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":538.3999999761581,"responseStart":0,"secureConnectionStart":0},{"duration":253.10000002384186,"initiatorType":"script","name":"https://jira.mariadb.org/s/3339d87fa2538a859872f2df449bf8d0-CDN/lu2bu7/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":331.5,"connectEnd":331.5,"connectStart":331.5,"domainLookupEnd":331.5,"domainLookupStart":331.5,"fetchStart":331.5,"redirectEnd":0,"redirectStart":0,"requestStart":559.1000000238419,"responseEnd":584.6000000238419,"responseStart":582.8000000119209,"secureConnectionStart":331.5},{"duration":492.4000000357628,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2bu7/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-js/jira.webresources:bigpipe-js.js","startTime":332.19999998807907,"connectEnd":332.19999998807907,"connectStart":332.19999998807907,"domainLookupEnd":332.19999998807907,"domainLookupStart":332.19999998807907,"fetchStart":332.19999998807907,"redirectEnd":0,"redirectStart":0,"requestStart":636.8000000119209,"responseEnd":824.6000000238419,"responseStart":820.1999999880791,"secureConnectionStart":332.19999998807907},{"duration":494.0999999642372,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2bu7/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-init/jira.webresources:bigpipe-init.js","startTime":332.30000001192093,"connectEnd":332.30000001192093,"connectStart":332.30000001192093,"domainLookupEnd":332.30000001192093,"domainLookupStart":332.30000001192093,"fetchStart":332.30000001192093,"redirectEnd":0,"redirectStart":0,"requestStart":787,"responseEnd":826.3999999761581,"responseStart":822.1000000238419,"secureConnectionStart":332.30000001192093},{"duration":144.5999999642372,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":843.1000000238419,"connectEnd":843.1000000238419,"connectStart":843.1000000238419,"domainLookupEnd":843.1000000238419,"domainLookupStart":843.1000000238419,"fetchStart":843.1000000238419,"redirectEnd":0,"redirectStart":0,"requestStart":947.8999999761581,"responseEnd":987.6999999880791,"responseStart":987.1000000238419,"secureConnectionStart":843.1000000238419},{"duration":282.5999999642372,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1068.1000000238419,"connectEnd":1068.1000000238419,"connectStart":1068.1000000238419,"domainLookupEnd":1068.1000000238419,"domainLookupStart":1068.1000000238419,"fetchStart":1068.1000000238419,"redirectEnd":0,"redirectStart":0,"requestStart":1318.5,"responseEnd":1350.699999988079,"responseStart":1349.8999999761581,"secureConnectionStart":1068.1000000238419}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":155,"responseStart":320,"responseEnd":324,"domLoading":324,"domInteractive":1256,"domContentLoadedEventStart":1256,"domContentLoadedEventEnd":1315,"domComplete":2320,"loadEventStart":2320,"loadEventEnd":2321,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1236.800000011921},{"name":"bigPipe.sidebar-id.end","time":1237.6000000238419},{"name":"bigPipe.activity-panel-pipe-id.start","time":1237.800000011921},{"name":"bigPipe.activity-panel-pipe-id.end","time":1240.300000011921},{"name":"activityTabFullyLoaded","time":1373.6000000238419}],"measures":[],"correlationId":"399ec828eb4d06","effectiveType":"4g","downlink":9.1,"rtt":0,"serverDuration":95,"dbReadsTimeInMs":12,"dbConnsTimeInMs":20,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}