Formatting more complex strings in a SELECT statement can get awkward when there are many concat(), format(), etc calls involved.
It would be very cool and helpful to have a function that takes an input string and a formatting specification and returns string formatted using the rules the user passed in the specification.
A great example for such a function is the classic C printf function, which, in this context, would look something like:
SELECT printf('%s %s, %s', first_name, last_name, job_title) from employees;
But it doesn't necessarily need to look this way, an alternative syntax could be Python-ish, which would leverage the fact that the server already knows the datatype of each field used in the formatting scheme:
Ideally, this new function should use, behind the scenes, the existing builtin formatting functions in MariaDB (e.g. date_format(), format()) and even future formatting functions (e.g. MySQL's format_bytes(), format_pico_time()), so the syntax has to be designed in a smart way to accommodate easily future additions.
Though it's covered in the testcase (input (5,5,5)) should this give a warning ("extraneous inputs/parameter found") - or the existing ERROR 1582 (42000): Incorrect parameter count in the call to native function 'sformat'?
Roel Van de Paar
added a comment - - edited Though it's covered in the testcase ( input (5,5,5) ) should this give a warning ("extraneous inputs/parameter found") - or the existing ERROR 1582 (42000): Incorrect parameter count in the call to native function 'sformat' ?
10.7.0 53b2c1f4664a3cb90f583979d9aa2771b7e1c98d (Debug)
10.7.0-dbg>SELECT SFORMAT(1,2,3);
+----------------+
| SFORMAT(1,2,3) |
+----------------+
| 1 |
+----------------+
1 row in set (0.000 sec)
Further testing has not revealed any additional issues save the one above.
Re-assigning back to serg for push to trunk if not done already.
Roel Van de Paar
added a comment - Further testing has not revealed any additional issues save the one above.
Re-assigning back to serg for push to trunk if not done already.
Trying to use named parameters ('{name}') doesn't return a specific error, though I couldn't find a way to make it work. Please clarify how to use named parameters in the docs, or produce an error that clarifies that this is not supported.
Federico Razzoli
added a comment - - edited Trying to use named parameters ('{name}') doesn't return a specific error, though I couldn't find a way to make it work. Please clarify how to use named parameters in the docs, or produce an error that clarifies that this is not supported.
This is the error message that libfmt returns. And yes named parameters don't work. It'd open a very special can of worms, consider, for example,
select sformat(concat("Column value: {", col, "}")) from t1;
which shoud show the value of a column which name is stored in the column col.
I'm not saying it's impossible to make it work, but it'd be very complex with tons of vague corner cases. We decided not to go there for now.
Sergei Golubchik
added a comment - This is the error message that libfmt returns. And yes named parameters don't work. It'd open a very special can of worms, consider, for example,
select sformat(concat( "Column value: {" , col, "}" )) from t1;
which shoud show the value of a column which name is stored in the column col .
I'm not saying it's impossible to make it work, but it'd be very complex with tons of vague corner cases. We decided not to go there for now.
I think there are ways to write obscure queries both with named and positional arguments. But it's reasonable to omit a feature from libfmt, I just think that it should be more clear.
Federico Razzoli
added a comment - I think there are ways to write obscure queries both with named and positional arguments. But it's reasonable to omit a feature from libfmt, I just think that it should be more clear.
People
Sergei Golubchik
Robert Bindar
Votes:
1Vote 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":954.5,"ttfb":315.40000009536743,"pageVisibility":"visible","entityId":97415,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"a6e6c56b-06f2-4345-badc-8bdcebbcdbd0","navigationType":0,"readyForUser":1123.8000001907349,"redirectCount":0,"resourceLoadedEnd":1253.8000001907349,"resourceLoadedStart":321.2000000476837,"resourceTiming":[{"duration":82.5,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":321.2000000476837,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":321.2000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":403.7000000476837,"responseStart":0,"secureConnectionStart":0},{"duration":83,"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":321.5,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":321.5,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":404.5,"responseStart":0,"secureConnectionStart":0},{"duration":154.79999995231628,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":321.7000000476837,"connectEnd":321.7000000476837,"connectStart":321.7000000476837,"domainLookupEnd":321.7000000476837,"domainLookupStart":321.7000000476837,"fetchStart":321.7000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":321.7000000476837,"responseEnd":476.5,"responseStart":476.5,"secureConnectionStart":321.7000000476837},{"duration":266.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":321.80000019073486,"connectEnd":321.80000019073486,"connectStart":321.80000019073486,"domainLookupEnd":321.80000019073486,"domainLookupStart":321.80000019073486,"fetchStart":321.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":321.80000019073486,"responseEnd":588.1000001430511,"responseStart":588.1000001430511,"secureConnectionStart":321.80000019073486},{"duration":270,"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":322.10000014305115,"connectEnd":322.10000014305115,"connectStart":322.10000014305115,"domainLookupEnd":322.10000014305115,"domainLookupStart":322.10000014305115,"fetchStart":322.10000014305115,"redirectEnd":0,"redirectStart":0,"requestStart":322.10000014305115,"responseEnd":592.1000001430511,"responseStart":592.1000001430511,"secureConnectionStart":322.10000014305115},{"duration":270.2999999523163,"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":322.30000019073486,"connectEnd":322.30000019073486,"connectStart":322.30000019073486,"domainLookupEnd":322.30000019073486,"domainLookupStart":322.30000019073486,"fetchStart":322.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":322.30000019073486,"responseEnd":592.6000001430511,"responseStart":592.6000001430511,"secureConnectionStart":322.30000019073486},{"duration":270.40000009536743,"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":322.5,"connectEnd":322.5,"connectStart":322.5,"domainLookupEnd":322.5,"domainLookupStart":322.5,"fetchStart":322.5,"redirectEnd":0,"redirectStart":0,"requestStart":322.5,"responseEnd":592.9000000953674,"responseStart":592.9000000953674,"secureConnectionStart":322.5},{"duration":299.59999990463257,"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":322.60000014305115,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":322.60000014305115,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":622.2000000476837,"responseStart":0,"secureConnectionStart":0},{"duration":270.5,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":322.80000019073486,"connectEnd":322.80000019073486,"connectStart":322.80000019073486,"domainLookupEnd":322.80000019073486,"domainLookupStart":322.80000019073486,"fetchStart":322.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":322.80000019073486,"responseEnd":593.3000001907349,"responseStart":593.3000001907349,"secureConnectionStart":322.80000019073486},{"duration":299.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":322.90000009536743,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":322.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":622.5,"responseStart":0,"secureConnectionStart":0},{"duration":270.89999985694885,"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":323.10000014305115,"connectEnd":323.10000014305115,"connectStart":323.10000014305115,"domainLookupEnd":323.10000014305115,"domainLookupStart":323.10000014305115,"fetchStart":323.10000014305115,"redirectEnd":0,"redirectStart":0,"requestStart":323.10000014305115,"responseEnd":594,"responseStart":594,"secureConnectionStart":323.10000014305115},{"duration":599.5999999046326,"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":324.90000009536743,"connectEnd":324.90000009536743,"connectStart":324.90000009536743,"domainLookupEnd":324.90000009536743,"domainLookupStart":324.90000009536743,"fetchStart":324.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":324.90000009536743,"responseEnd":924.5,"responseStart":924.5,"secureConnectionStart":324.90000009536743},{"duration":888,"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":329.5,"connectEnd":329.5,"connectStart":329.5,"domainLookupEnd":329.5,"domainLookupStart":329.5,"fetchStart":329.5,"redirectEnd":0,"redirectStart":0,"requestStart":329.5,"responseEnd":1217.5,"responseStart":1217.5,"secureConnectionStart":329.5},{"duration":259.7000000476837,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":665.1000001430511,"connectEnd":665.1000001430511,"connectStart":665.1000001430511,"domainLookupEnd":665.1000001430511,"domainLookupStart":665.1000001430511,"fetchStart":665.1000001430511,"redirectEnd":0,"redirectStart":0,"requestStart":665.1000001430511,"responseEnd":924.8000001907349,"responseStart":924.8000001907349,"secureConnectionStart":665.1000001430511},{"duration":300.7000000476837,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":947.9000000953674,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":947.9000000953674,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1248.6000001430511,"responseStart":0,"secureConnectionStart":0},{"duration":275.2999999523163,"initiatorType":"link","name":"https://jira.mariadb.org/s/d5715adaadd168a9002b108b2b039b50-CDN/lu2cib/820016/12ta74/be4b45e9cec53099498fa61c8b7acba4/_/download/contextbatch/css/jira.project.sidebar,-_super,-project.issue.navigator,-jira.general,-jira.browse.project,-jira.view.issue,-jira.global,-atl.general,-com.atlassian.jira.projects.sidebar.init/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":971.6000001430511,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":971.6000001430511,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1246.9000000953674,"responseStart":0,"secureConnectionStart":0},{"duration":273.89999985694885,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/e65b778d185daf5aee24936755b43da6/_/download/contextbatch/js/browser-metrics-plugin.contrib,-_super,-project.issue.navigator,-jira.view.issue,-atl.general/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":972.6000001430511,"connectEnd":972.6000001430511,"connectStart":972.6000001430511,"domainLookupEnd":972.6000001430511,"domainLookupStart":972.6000001430511,"fetchStart":972.6000001430511,"redirectEnd":0,"redirectStart":0,"requestStart":972.6000001430511,"responseEnd":1246.5,"responseStart":1246.5,"secureConnectionStart":972.6000001430511},{"duration":280.7000000476837,"initiatorType":"script","name":"https://jira.mariadb.org/s/097ae97cb8fbec7d6ea4bbb1f26955b9-CDN/lu2cib/820016/12ta74/be4b45e9cec53099498fa61c8b7acba4/_/download/contextbatch/js/jira.project.sidebar,-_super,-project.issue.navigator,-jira.general,-jira.browse.project,-jira.view.issue,-jira.global,-atl.general,-com.atlassian.jira.projects.sidebar.init/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&locale=en&slack-enabled=true&whisper-enabled=true","startTime":973.1000001430511,"connectEnd":973.1000001430511,"connectStart":973.1000001430511,"domainLookupEnd":973.1000001430511,"domainLookupStart":973.1000001430511,"fetchStart":973.1000001430511,"redirectEnd":0,"redirectStart":0,"requestStart":973.1000001430511,"responseEnd":1253.8000001907349,"responseStart":1253.8000001907349,"secureConnectionStart":973.1000001430511}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":140,"responseStart":316,"responseEnd":323,"domLoading":319,"domInteractive":1256,"domContentLoadedEventStart":1256,"domContentLoadedEventEnd":1306,"domComplete":1491,"loadEventStart":1491,"loadEventEnd":1492,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1219.6000001430511},{"name":"bigPipe.sidebar-id.end","time":1220.4000000953674},{"name":"bigPipe.activity-panel-pipe-id.start","time":1220.6000001430511},{"name":"bigPipe.activity-panel-pipe-id.end","time":1222.8000001907349},{"name":"activityTabFullyLoaded","time":1324.6000001430511}],"measures":[],"correlationId":"36b9d858ac4090","effectiveType":"4g","downlink":10,"rtt":0,"serverDuration":112,"dbReadsTimeInMs":18,"dbConnsTimeInMs":27,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
Though it's covered in the testcase (input (5,5,5)) should this give a warning ("extraneous inputs/parameter found") - or the existing ERROR 1582 (42000): Incorrect parameter count in the call to native function 'sformat'?
10.7.0 53b2c1f4664a3cb90f583979d9aa2771b7e1c98d (Debug)
10.7.0-dbg>SELECT SFORMAT(1,2,3);
+----------------+
| SFORMAT(1,2,3) |
+----------------+
| 1 |
+----------------+
1 row in set (0.000 sec)