If a window function is used without specifying either partition or order list (which is valid and makes sense at least with row_number() function), the server fails an assertion:
create table t40 (a int) engine=InnoDB;
|
select row_number() over () from t40;
|
mysqld: /src/10.2/sql/filesort.h:70: Filesort::Filesort(ORDER*, ha_rows, bool, SQL_SELECT*): Assertion `order' failed.
|
160521 19:13:05 [ERROR] mysqld got signal 6 ;
|
Program received signal SIGABRT, Aborted.
|
0x00007ffff5f90425 in __GI_raise (sig=<optimized out>) at ../nptl/sysdeps/unix/sysv/linux/raise.c:64
|
64 ../nptl/sysdeps/unix/sysv/linux/raise.c: No such file or directory.
|
(gdb) wher
|
#0 0x00007ffff5f90425 in __GI_raise (sig=<optimized out>) at ../nptl/sysdeps/unix/sysv/linux/raise.c:64
|
#1 0x00007ffff5f93b8b in __GI_abort () at abort.c:91
|
#2 0x00007ffff5f890ee in __assert_fail_base (fmt=<optimized out>, assertion=0x5555563e45cb "order", file=0x5555563e4590 "/home/psergey/dev-git/10.2-window-funcs-r10/sql/filesort.h", line=<optimized out>, function=<optimized out>) at assert.c:94
|
#3 0x00007ffff5f89192 in __GI___assert_fail (assertion=0x5555563e45cb "order", file=0x5555563e4590 "/home/psergey/dev-git/10.2-window-funcs-r10/sql/filesort.h", line=70, function=0x5555563e8940 "Filesort::Filesort(ORDER*, ha_rows, bool, SQL_SELECT*)") at assert.c:103
|
#4 0x0000555555b01c16 in Filesort::Filesort (this=0x7fff5c013560, order_arg=0x0, limit_arg=18446744073709551615, sort_positions_arg=true, select_arg=0x0) at /home/psergey/dev-git/10.2-window-funcs-r10/sql/filesort.h:70
|
#5 0x0000555555c2bcd8 in Window_funcs_sort::setup (this=0x7fff5c013518, thd=0x7fff5c000b00, sel=0x0, it=...) at /home/psergey/dev-git/10.2-window-funcs-r10/sql/sql_window.cc:1922
|
#6 0x0000555555c2be0f in Window_funcs_computation::setup (this=0x7fff5c0134f8, thd=0x7fff5c000b00, window_funcs=0x7fff5c004fc8, tab=0x7fff5c0128a0) at /home/psergey/dev-git/10.2-window-funcs-r10/sql/sql_window.cc:1949
|
#7 0x0000555555ac5573 in JOIN::make_aggr_tables_info (this=0x7fff5c011508) at /home/psergey/dev-git/10.2-window-funcs-r10/sql/sql_select.cc:2670
|
#8 0x0000555555ac30b6 in JOIN::optimize_inner (this=0x7fff5c011508) at /home/psergey/dev-git/10.2-window-funcs-r10/sql/sql_select.cc:2068
|
#9 0x0000555555abfc2c in JOIN::optimize (this=0x7fff5c011508) at /home/psergey/dev-git/10.2-window-funcs-r10/sql/sql_select.cc:1063
|
#10 0x0000555555ac7ed0 in mysql_select (thd=0x7fff5c000b00, tables=0x7fff5c010e10, wild_num=0, fields=..., conds=0x0, og_num=0, order=0x0, group=0x0, having=0x0, proc_param=0x0, select_options=2147748608, result=0x7fff5c0114e8, unit=0x7fff5c004550, select_lex=0x7fff5c004c70) at /home/psergey/dev-git/10.2-window-funcs-r10/sql/sql_select.cc:3521
|
The assertion fails here:
Filesort(ORDER *order_arg, ha_rows limit_arg, bool sort_positions_arg,
|
SQL_SELECT *select_arg):
|
order(order_arg),
|
...
|
{
|
DBUG_ASSERT(order);
|
};
|
{"report":{"fcp":1067.4000000953674,"ttfb":334.7999999523163,"pageVisibility":"visible","entityId":56453,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":32,"apdex":0.5,"journeyId":"15797355-9534-4720-b887-c652182cbfb9","navigationType":0,"readyForUser":1183.2999999523163,"redirectCount":0,"resourceLoadedEnd":1267,"resourceLoadedStart":344.7999999523163,"resourceTiming":[{"duration":232.20000004768372,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":344.7999999523163,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":344.7999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":577,"responseStart":0,"secureConnectionStart":0},{"duration":232.09999990463257,"initiatorType":"link","name":"https://jira.mariadb.org/s/7ebd35e77e471bc30ff0eba799ebc151-CDN/lu2cib/820016/12ta74/2bf333562ca6724060a9d5f1535471f6/_/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":345.2000000476837,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":345.2000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":577.2999999523163,"responseStart":0,"secureConnectionStart":0},{"duration":241,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":345.2999999523163,"connectEnd":345.2999999523163,"connectStart":345.2999999523163,"domainLookupEnd":345.2999999523163,"domainLookupStart":345.2999999523163,"fetchStart":345.2999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":345.2999999523163,"responseEnd":586.2999999523163,"responseStart":586.2999999523163,"secureConnectionStart":345.2999999523163},{"duration":293.7000000476837,"initiatorType":"script","name":"https://jira.mariadb.org/s/2d8175ec2fa4c816e8023260bd8c1786-CDN/lu2cib/820016/12ta74/2bf333562ca6724060a9d5f1535471f6/_/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":345.5,"connectEnd":345.5,"connectStart":345.5,"domainLookupEnd":345.5,"domainLookupStart":345.5,"fetchStart":345.5,"redirectEnd":0,"redirectStart":0,"requestStart":345.5,"responseEnd":639.2000000476837,"responseStart":639.2000000476837,"secureConnectionStart":345.5},{"duration":297.2000000476837,"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":345.7000000476837,"connectEnd":345.7000000476837,"connectStart":345.7000000476837,"domainLookupEnd":345.7000000476837,"domainLookupStart":345.7000000476837,"fetchStart":345.7000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":345.7000000476837,"responseEnd":642.9000000953674,"responseStart":642.9000000953674,"secureConnectionStart":345.7000000476837},{"duration":297.5,"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":345.90000009536743,"connectEnd":345.90000009536743,"connectStart":345.90000009536743,"domainLookupEnd":345.90000009536743,"domainLookupStart":345.90000009536743,"fetchStart":345.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":345.90000009536743,"responseEnd":643.4000000953674,"responseStart":643.4000000953674,"secureConnectionStart":345.90000009536743},{"duration":297.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":346.10000014305115,"connectEnd":346.10000014305115,"connectStart":346.10000014305115,"domainLookupEnd":346.10000014305115,"domainLookupStart":346.10000014305115,"fetchStart":346.10000014305115,"redirectEnd":0,"redirectStart":0,"requestStart":346.10000014305115,"responseEnd":643.7999999523163,"responseStart":643.7999999523163,"secureConnectionStart":346.10000014305115},{"duration":388.60000014305115,"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":346.2999999523163,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":346.2999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":734.9000000953674,"responseStart":0,"secureConnectionStart":0},{"duration":298.10000014305115,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":346.5,"connectEnd":346.5,"connectStart":346.5,"domainLookupEnd":346.5,"domainLookupStart":346.5,"fetchStart":346.5,"redirectEnd":0,"redirectStart":0,"requestStart":346.5,"responseEnd":644.6000001430511,"responseStart":644.6000001430511,"secureConnectionStart":346.5},{"duration":388.40000009536743,"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":346.7000000476837,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":346.7000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":735.1000001430511,"responseStart":0,"secureConnectionStart":0},{"duration":298.5,"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":346.90000009536743,"connectEnd":346.90000009536743,"connectStart":346.90000009536743,"domainLookupEnd":346.90000009536743,"domainLookupStart":346.90000009536743,"fetchStart":346.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":346.90000009536743,"responseEnd":645.4000000953674,"responseStart":645.4000000953674,"secureConnectionStart":346.90000009536743},{"duration":535.8999998569489,"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":355.10000014305115,"connectEnd":355.10000014305115,"connectStart":355.10000014305115,"domainLookupEnd":355.10000014305115,"domainLookupStart":355.10000014305115,"fetchStart":355.10000014305115,"redirectEnd":0,"redirectStart":0,"requestStart":355.10000014305115,"responseEnd":891,"responseStart":891,"secureConnectionStart":355.10000014305115},{"duration":895.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":356.60000014305115,"connectEnd":356.60000014305115,"connectStart":356.60000014305115,"domainLookupEnd":356.60000014305115,"domainLookupStart":356.60000014305115,"fetchStart":356.60000014305115,"redirectEnd":0,"redirectStart":0,"requestStart":356.60000014305115,"responseEnd":1252.1000001430511,"responseStart":1252,"secureConnectionStart":356.60000014305115},{"duration":147.90000009536743,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":747,"connectEnd":747,"connectStart":747,"domainLookupEnd":747,"domainLookupStart":747,"fetchStart":747,"redirectEnd":0,"redirectStart":0,"requestStart":747,"responseEnd":894.9000000953674,"responseStart":894.9000000953674,"secureConnectionStart":747},{"duration":261.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","startTime":1005.1000001430511,"connectEnd":1005.1000001430511,"connectStart":1005.1000001430511,"domainLookupEnd":1005.1000001430511,"domainLookupStart":1005.1000001430511,"fetchStart":1005.1000001430511,"redirectEnd":0,"redirectStart":0,"requestStart":1005.1000001430511,"responseEnd":1267,"responseStart":1267,"secureConnectionStart":1005.1000001430511},{"duration":214.29999995231628,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":1059.9000000953674,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1059.9000000953674,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1274.2000000476837,"responseStart":0,"secureConnectionStart":0}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":149,"responseStart":335,"responseEnd":356,"domLoading":343,"domInteractive":1277,"domContentLoadedEventStart":1277,"domContentLoadedEventEnd":1319,"domComplete":1650,"loadEventStart":1650,"loadEventEnd":1651,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1253.7999999523163},{"name":"bigPipe.sidebar-id.end","time":1254.7000000476837},{"name":"bigPipe.activity-panel-pipe-id.start","time":1254.9000000953674},{"name":"bigPipe.activity-panel-pipe-id.end","time":1256.6000001430511},{"name":"activityTabFullyLoaded","time":1334.2000000476837}],"measures":[],"correlationId":"35fef19454cb65","effectiveType":"4g","downlink":10,"rtt":0,"serverDuration":116,"dbReadsTimeInMs":16,"dbConnsTimeInMs":25,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
Indeed, filesort cannot use an empty criteria. We should support the case where window functions code doesn't need to do sorting.
It's possible to work around the assert by just putting in a dummy sort expression, but that's not the right way to do it.