It appears that when both ORDER BY and HAVING are present, HAVING is treated as WHERE clause.
Note: I don't see anything about it in the standard, maybe it's not even a part of the standard at all, the behavior just does not look logical.
create table empsalary (depname varchar(32), empno smallint primary key, salary int);
|
insert into empsalary values ('develop',1,5000),('develop',2,4000),('sales',3,'6000'),('sales',4,5000);
|
No ORDER BY, no HAVING -- OK
|
MariaDB [test]> SELECT depname, empno, salary, avg(salary) OVER (PARTITION BY depname) FROM empsalary;
|
+---------+-------+--------+-----------------------------------------+
|
| depname | empno | salary | avg(salary) OVER (PARTITION BY depname) |
|
+---------+-------+--------+-----------------------------------------+
|
| develop | 1 | 5000 | 4500.0000 |
|
| develop | 2 | 4000 | 4500.0000 |
|
| sales | 3 | 6000 | 5500.0000 |
|
| sales | 4 | 5000 | 5500.0000 |
|
+---------+-------+--------+-----------------------------------------+
|
ORDER BY, no HAVING -- OK
|
MariaDB [test]> SELECT depname, empno, salary, avg(salary) OVER (PARTITION BY depname) FROM empsalary order by depname;
|
+---------+-------+--------+-----------------------------------------+
|
| depname | empno | salary | avg(salary) OVER (PARTITION BY depname) |
|
+---------+-------+--------+-----------------------------------------+
|
| develop | 1 | 5000 | 4500.0000 |
|
| develop | 2 | 4000 | 4500.0000 |
|
| sales | 4 | 5000 | 5500.0000 |
|
| sales | 3 | 6000 | 5500.0000 |
|
+---------+-------+--------+-----------------------------------------+
|
HAVING, no ORDER BY -- WRONG
|
MariaDB [test]> SELECT depname, empno, salary, avg(salary) OVER (PARTITION BY depname) FROM empsalary having empno > 1;
|
+---------+-------+--------+-----------------------------------------+
|
| depname | empno | salary | avg(salary) OVER (PARTITION BY depname) |
|
+---------+-------+--------+-----------------------------------------+
|
| develop | 2 | 4000 | 4500.0000 |
|
| sales | 3 | 6000 | 5500.0000 |
|
| sales | 4 | 5000 | 5500.0000 |
|
+---------+-------+--------+-----------------------------------------+
|
3 rows in set (0.00 sec)
|
ORDER BY and HAVING -- OK
|
MariaDB [test]> SELECT depname, empno, salary, avg(salary) OVER (PARTITION BY depname) FROM empsalary having empno > 1 order by depname;
|
+---------+-------+--------+-----------------------------------------+
|
| depname | empno | salary | avg(salary) OVER (PARTITION BY depname) |
|
+---------+-------+--------+-----------------------------------------+
|
| develop | 2 | 4000 | 4000.0000 |
|
| sales | 4 | 5000 | 5500.0000 |
|
| sales | 3 | 6000 | 5500.0000 |
|
+---------+-------+--------+-----------------------------------------+
|
3 rows in set (0.00 sec)
|
- relates to
-
MDEV-9896
Testing for window functions
-
-
Open
{"report":{"fcp":1217.8000001907349,"ttfb":343.2000002861023,"pageVisibility":"visible","entityId":58168,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"ab529667-f3cb-4936-8eac-63f5e6abb08e","navigationType":0,"readyForUser":1305,"redirectCount":0,"resourceLoadedEnd":1398.9000000953674,"resourceLoadedStart":361.80000019073486,"resourceTiming":[{"duration":8.799999713897705,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":361.80000019073486,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":361.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":370.59999990463257,"responseStart":0,"secureConnectionStart":0},{"duration":10.099999904632568,"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":362.2000002861023,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":362.2000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":372.30000019073486,"responseStart":0,"secureConnectionStart":0},{"duration":386.5,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":362.40000009536743,"connectEnd":362.40000009536743,"connectStart":362.40000009536743,"domainLookupEnd":362.40000009536743,"domainLookupStart":362.40000009536743,"fetchStart":362.40000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":362.40000009536743,"responseEnd":748.9000000953674,"responseStart":748.9000000953674,"secureConnectionStart":362.40000009536743},{"duration":473.90000009536743,"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":363.5,"connectEnd":363.5,"connectStart":363.5,"domainLookupEnd":363.5,"domainLookupStart":363.5,"fetchStart":363.5,"redirectEnd":0,"redirectStart":0,"requestStart":363.5,"responseEnd":837.4000000953674,"responseStart":837.4000000953674,"secureConnectionStart":363.5},{"duration":387,"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":363.80000019073486,"connectEnd":363.80000019073486,"connectStart":363.80000019073486,"domainLookupEnd":363.80000019073486,"domainLookupStart":363.80000019073486,"fetchStart":363.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":363.80000019073486,"responseEnd":750.8000001907349,"responseStart":750.8000001907349,"secureConnectionStart":363.80000019073486},{"duration":477.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":363.90000009536743,"connectEnd":363.90000009536743,"connectStart":363.90000009536743,"domainLookupEnd":363.90000009536743,"domainLookupStart":363.90000009536743,"fetchStart":363.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":363.90000009536743,"responseEnd":841.8000001907349,"responseStart":841.8000001907349,"secureConnectionStart":363.90000009536743},{"duration":478,"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":364.09999990463257,"connectEnd":364.09999990463257,"connectStart":364.09999990463257,"domainLookupEnd":364.09999990463257,"domainLookupStart":364.09999990463257,"fetchStart":364.09999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":364.09999990463257,"responseEnd":842.0999999046326,"responseStart":842.0999999046326,"secureConnectionStart":364.09999990463257},{"duration":10.699999809265137,"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":364.30000019073486,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":364.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":375,"responseStart":0,"secureConnectionStart":0},{"duration":478.19999980926514,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":364.30000019073486,"connectEnd":364.30000019073486,"connectStart":364.30000019073486,"domainLookupEnd":364.30000019073486,"domainLookupStart":364.30000019073486,"fetchStart":364.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":364.30000019073486,"responseEnd":842.5,"responseStart":842.5,"secureConnectionStart":364.30000019073486},{"duration":11.200000286102295,"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":364.59999990463257,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":364.59999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":375.80000019073486,"responseStart":0,"secureConnectionStart":0},{"duration":478.2999997138977,"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":364.7000002861023,"connectEnd":364.7000002861023,"connectStart":364.7000002861023,"domainLookupEnd":364.7000002861023,"domainLookupStart":364.7000002861023,"fetchStart":364.7000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":364.7000002861023,"responseEnd":843,"responseStart":843,"secureConnectionStart":364.7000002861023},{"duration":477,"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":366.30000019073486,"connectEnd":366.30000019073486,"connectStart":366.30000019073486,"domainLookupEnd":366.30000019073486,"domainLookupStart":366.30000019073486,"fetchStart":366.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":366.30000019073486,"responseEnd":843.3000001907349,"responseStart":843.3000001907349,"secureConnectionStart":366.30000019073486},{"duration":477.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":366.40000009536743,"connectEnd":366.40000009536743,"connectStart":366.40000009536743,"domainLookupEnd":366.40000009536743,"domainLookupStart":366.40000009536743,"fetchStart":366.40000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":366.40000009536743,"responseEnd":843.9000000953674,"responseStart":843.9000000953674,"secureConnectionStart":366.40000009536743},{"duration":58.5,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":908.7000002861023,"connectEnd":908.7000002861023,"connectStart":908.7000002861023,"domainLookupEnd":908.7000002861023,"domainLookupStart":908.7000002861023,"fetchStart":908.7000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":908.7000002861023,"responseEnd":967.2000002861023,"responseStart":967.2000002861023,"secureConnectionStart":908.7000002861023},{"duration":228,"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":1170.5999999046326,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1170.5999999046326,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1398.5999999046326,"responseStart":0,"secureConnectionStart":0},{"duration":227.80000019073486,"initiatorType":"link","name":"https://jira.mariadb.org/s/50bc9be5bfead1a25e72c1a9338c94f6-CDN/lu2cib/820016/12ta74/e108c7645258ccb43280ed3404e3e949/_/download/contextbatch/css/com.atlassian.jira.plugins.jira-development-integration-plugin:0,-_super,-jira.view.issue,-jira.global,-jira.general,-jira.browse.project,-project.issue.navigator,-atl.general/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":1171.0999999046326,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1171.0999999046326,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1398.9000000953674,"responseStart":0,"secureConnectionStart":0},{"duration":173.40000009536743,"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":1172,"connectEnd":1172,"connectStart":1172,"domainLookupEnd":1172,"domainLookupStart":1172,"fetchStart":1172,"redirectEnd":0,"redirectStart":0,"requestStart":1172,"responseEnd":1345.4000000953674,"responseStart":1345.4000000953674,"secureConnectionStart":1172},{"duration":179.30000019073486,"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":1172.4000000953674,"connectEnd":1172.4000000953674,"connectStart":1172.4000000953674,"domainLookupEnd":1172.4000000953674,"domainLookupStart":1172.4000000953674,"fetchStart":1172.4000000953674,"redirectEnd":0,"redirectStart":0,"requestStart":1172.4000000953674,"responseEnd":1351.7000002861023,"responseStart":1351.7000002861023,"secureConnectionStart":1172.4000000953674},{"duration":180.2999997138977,"initiatorType":"script","name":"https://jira.mariadb.org/s/e0bf5781d46ea69fb123572974cf39de-CDN/lu2cib/820016/12ta74/e108c7645258ccb43280ed3404e3e949/_/download/contextbatch/js/com.atlassian.jira.plugins.jira-development-integration-plugin:0,-_super,-jira.view.issue,-jira.global,-jira.general,-jira.browse.project,-project.issue.navigator,-atl.general/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&locale=en&slack-enabled=true&whisper-enabled=true","startTime":1172.7000002861023,"connectEnd":1172.7000002861023,"connectStart":1172.7000002861023,"domainLookupEnd":1172.7000002861023,"domainLookupStart":1172.7000002861023,"fetchStart":1172.7000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":1172.7000002861023,"responseEnd":1353,"responseStart":1353,"secureConnectionStart":1172.7000002861023},{"duration":209.5,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":1211.7000002861023,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1211.7000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1421.2000002861023,"responseStart":0,"secureConnectionStart":0}],"fetchStart":0,"domainLookupStart":10,"domainLookupEnd":126,"connectStart":126,"connectEnd":151,"secureConnectionStart":134,"requestStart":152,"responseStart":343,"responseEnd":362,"domLoading":346,"domInteractive":1432,"domContentLoadedEventStart":1432,"domContentLoadedEventEnd":1487,"domComplete":1644,"loadEventStart":1644,"loadEventEnd":1644,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1404.0999999046326},{"name":"bigPipe.sidebar-id.end","time":1404.9000000953674},{"name":"bigPipe.activity-panel-pipe-id.start","time":1405},{"name":"bigPipe.activity-panel-pipe-id.end","time":1406.5999999046326},{"name":"activityTabFullyLoaded","time":1517.5999999046326}],"measures":[],"correlationId":"ae837c78bcfe66","effectiveType":"4g","downlink":10,"rtt":0,"serverDuration":109,"dbReadsTimeInMs":19,"dbConnsTimeInMs":29,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}