In order to emulate Oracle's behavior in handling empty strings as NULL, we'll add a new sql_mode flag EMPTY_STRING_IS_NULL.
When this flag is set, we will:
translate Item_string created in the parser to Item_null
translate binding an empty string as prepared statement parameters to binding NULL
Note, more NULL handling flags will be added later under terms of separate patch:
translating empty strings in function return values to NULL
handling empty strings as equal to NULL in comparison operators
This task is only about literals and PS parameters.
The new flag will be disabled by default.
The new flag will NOT be a part of sql_mode=ORACLE.
In order to activate this behavior, one will have to do:
SET sql_mode='ORACLE,EMPTY_STRING_IS_NULL';
Attachments
Issue Links
relates to
MDEV-16471mysqldump throws "Variable 'sql_mode' can't be set to the value of 'NULL' (1231)"
Closed
MDEV-23253EMPTY_STRING_IS_NULL: error setting a not-NULL system variable to empty string
Open
MDEV-27744LPAD in vcol created in ORACLE mode makes table corrupted in non-ORACLE
Hi team,
I am getting the same issue when trying to set SQL_MODE as EMPTY_STRING_IS_NULL in Server version: 10.3.2-MariaDB MariaDB Server to compatible with ORACLE.
getting below error for your reference :
ERROR 1231 (42000): Variable 'sql_mode' can't be set to the value of 'EMPTY_STRING_IS_NULL'
Anil
added a comment - Hi team,
I am getting the same issue when trying to set SQL_MODE as EMPTY_STRING_IS_NULL in Server version: 10.3.2-MariaDB MariaDB Server to compatible with ORACLE.
getting below error for your reference :
ERROR 1231 (42000): Variable 'sql_mode' can't be set to the value of 'EMPTY_STRING_IS_NULL'
Anil
added a comment - Please suggest how to fix if I want both the SQL_MODE active on MariaDB 10.3.2 server.
SQL_MODE =STRICT_TRANS_TABLES, EMPTY_STRING_IS_NULL
Thanks in advance
Anil
I am confused about this feature - is this supposed to work for LOAD DATA INFILE and mysqlimport loads as well?
My version is 10.3.9-MariaDB-1:10.3.9+maria~xenial-log
I have a MyISAM table with an int(11) column user_id which has DEFAULT NULL defined.
When I insert records into this table using the INSERT INTO... command, using empty strings for user_id, I get the expected NULL for user_id.
But when I try to load CSV data which is empty on the user_id field (as in "nothing between the commas"), the user_id for those rows is set to 0 (zero).
This happens for both LOAD DATA INFILE and mysqlimport.
Please advise.
Mike Hawksfraert
added a comment - - edited I am confused about this feature - is this supposed to work for LOAD DATA INFILE and mysqlimport loads as well?
My version is 10.3.9-MariaDB-1:10.3.9+maria~xenial-log
I have a MyISAM table with an int(11) column user_id which has DEFAULT NULL defined.
When I insert records into this table using the INSERT INTO... command, using empty strings for user_id, I get the expected NULL for user_id.
But when I try to load CSV data which is empty on the user_id field (as in "nothing between the commas"), the user_id for those rows is set to 0 (zero).
This happens for both LOAD DATA INFILE and mysqlimport.
Please advise.
People
Alexander Barkov
Alexander Barkov
Votes:
0Vote for this issue
Watchers:
5Start 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":1294.1999998092651,"ttfb":689,"pageVisibility":"visible","entityId":63502,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"92cc1684-984f-496f-bb46-b31ef425f71c","navigationType":0,"readyForUser":1360.6999998092651,"redirectCount":0,"resourceLoadedEnd":1413.4000005722046,"resourceLoadedStart":697.5,"resourceTiming":[{"duration":51.19999980926514,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":697.5,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":697.5,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":748.6999998092651,"responseStart":0,"secureConnectionStart":0},{"duration":51.60000038146973,"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":697.8000001907349,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":697.8000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":749.4000005722046,"responseStart":0,"secureConnectionStart":0},{"duration":122,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":698,"connectEnd":698,"connectStart":698,"domainLookupEnd":698,"domainLookupStart":698,"fetchStart":698,"redirectEnd":0,"redirectStart":0,"requestStart":756.8000001907349,"responseEnd":820,"responseStart":790.1999998092651,"secureConnectionStart":698},{"duration":140.20000076293945,"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":699.1999998092651,"connectEnd":699.1999998092651,"connectStart":699.1999998092651,"domainLookupEnd":699.1999998092651,"domainLookupStart":699.1999998092651,"fetchStart":699.1999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":757.1999998092651,"responseEnd":839.4000005722046,"responseStart":787,"secureConnectionStart":699.1999998092651},{"duration":92.80000019073486,"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":699.3000001907349,"connectEnd":699.3000001907349,"connectStart":699.3000001907349,"domainLookupEnd":699.3000001907349,"domainLookupStart":699.3000001907349,"fetchStart":699.3000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":757.9000005722046,"responseEnd":792.1000003814697,"responseStart":789.3000001907349,"secureConnectionStart":699.3000001907349},{"duration":344.1000003814697,"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":699.5,"connectEnd":699.5,"connectStart":699.5,"domainLookupEnd":699.5,"domainLookupStart":699.5,"fetchStart":699.5,"redirectEnd":0,"redirectStart":0,"requestStart":1031.1999998092651,"responseEnd":1043.6000003814697,"responseStart":1042.9000005722046,"secureConnectionStart":699.5},{"duration":345.20000076293945,"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":699.6999998092651,"connectEnd":699.6999998092651,"connectStart":699.6999998092651,"domainLookupEnd":699.6999998092651,"domainLookupStart":699.6999998092651,"fetchStart":699.6999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":1032.9000005722046,"responseEnd":1044.9000005722046,"responseStart":1044.1999998092651,"secureConnectionStart":699.6999998092651},{"duration":472.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":699.8000001907349,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":699.8000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1172.4000005722046,"responseStart":0,"secureConnectionStart":0},{"duration":346.4000005722046,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":700,"connectEnd":700,"connectStart":700,"domainLookupEnd":700,"domainLookupStart":700,"fetchStart":700,"redirectEnd":0,"redirectStart":0,"requestStart":1035.4000005722046,"responseEnd":1046.4000005722046,"responseStart":1045.8000001907349,"secureConnectionStart":700},{"duration":472.3999996185303,"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":700.1000003814697,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":700.1000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1172.5,"responseStart":0,"secureConnectionStart":0},{"duration":348.19999980926514,"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":700.3000001907349,"connectEnd":700.3000001907349,"connectStart":700.3000001907349,"domainLookupEnd":700.3000001907349,"domainLookupStart":700.3000001907349,"fetchStart":700.3000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":1037,"responseEnd":1048.5,"responseStart":1047.6999998092651,"secureConnectionStart":700.3000001907349},{"duration":568.3999996185303,"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":701.3000001907349,"connectEnd":701.3000001907349,"connectStart":701.3000001907349,"domainLookupEnd":701.3000001907349,"domainLookupStart":701.3000001907349,"fetchStart":701.3000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":1257.5,"responseEnd":1269.6999998092651,"responseStart":1268.6999998092651,"secureConnectionStart":701.3000001907349},{"duration":711.5,"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":701.9000005722046,"connectEnd":701.9000005722046,"connectStart":701.9000005722046,"domainLookupEnd":701.9000005722046,"domainLookupStart":701.9000005722046,"fetchStart":701.9000005722046,"redirectEnd":0,"redirectStart":0,"requestStart":1401.6000003814697,"responseEnd":1413.4000005722046,"responseStart":1412.8000001907349,"secureConnectionStart":701.9000005722046},{"duration":224.80000019073486,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1031.6999998092651,"connectEnd":1031.6999998092651,"connectStart":1031.6999998092651,"domainLookupEnd":1031.6999998092651,"domainLookupStart":1031.6999998092651,"fetchStart":1031.6999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":1219.1000003814697,"responseEnd":1256.5,"responseStart":1255.8000001907349,"secureConnectionStart":1031.6999998092651},{"duration":198.89999961853027,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":1287.9000005722046,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1287.9000005722046,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1486.8000001907349,"responseStart":0,"secureConnectionStart":0},{"duration":207.19999980926514,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1294.1000003814697,"connectEnd":1294.1000003814697,"connectStart":1294.1000003814697,"domainLookupEnd":1294.1000003814697,"domainLookupStart":1294.1000003814697,"fetchStart":1294.1000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":1463,"responseEnd":1501.3000001907349,"responseStart":1500.6000003814697,"secureConnectionStart":1294.1000003814697}],"fetchStart":0,"domainLookupStart":42,"domainLookupEnd":64,"connectStart":65,"connectEnd":83,"secureConnectionStart":73,"requestStart":84,"responseStart":689,"responseEnd":696,"domLoading":692,"domInteractive":1447,"domContentLoadedEventStart":1447,"domContentLoadedEventEnd":1486,"domComplete":2001,"loadEventStart":2001,"loadEventEnd":2001,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1425.8000001907349},{"name":"bigPipe.sidebar-id.end","time":1426.6000003814697},{"name":"bigPipe.activity-panel-pipe-id.start","time":1426.8000001907349},{"name":"bigPipe.activity-panel-pipe-id.end","time":1428.4000005722046},{"name":"activityTabFullyLoaded","time":1503.5}],"measures":[],"correlationId":"3beb27a7f45949","effectiveType":"4g","downlink":9,"rtt":0,"serverDuration":126,"dbReadsTimeInMs":13,"dbConnsTimeInMs":23,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
Reviewed a contributed patch from Jerome B.
Proposes a few small cleanups.
Pushed.