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":1072.3999999761581,"ttfb":249.89999997615814,"pageVisibility":"visible","entityId":56453,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"3a5d8364-e04f-4161-a644-88d463b99b16","navigationType":0,"readyForUser":1159.6999999284744,"redirectCount":0,"resourceLoadedEnd":806.7999999523163,"resourceLoadedStart":255.60000002384186,"resourceTiming":[{"duration":258.59999990463257,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2bu7/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":255.60000002384186,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":255.60000002384186,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":514.1999999284744,"responseStart":0,"secureConnectionStart":0},{"duration":259.60000002384186,"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":255.79999995231628,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":255.79999995231628,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":515.3999999761581,"responseStart":0,"secureConnectionStart":0},{"duration":415.5,"initiatorType":"script","name":"https://jira.mariadb.org/s/fbf975c0cce4b1abf04784eeae9ba1f4-CDN/lu2bu7/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":256,"connectEnd":256,"connectStart":256,"domainLookupEnd":256,"domainLookupStart":256,"fetchStart":256,"redirectEnd":0,"redirectStart":0,"requestStart":518.7999999523163,"responseEnd":671.5,"responseStart":536.5,"secureConnectionStart":256},{"duration":284.6999999284744,"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":256.10000002384186,"connectEnd":256.10000002384186,"connectStart":256.10000002384186,"domainLookupEnd":256.10000002384186,"domainLookupStart":256.10000002384186,"fetchStart":256.10000002384186,"redirectEnd":0,"redirectStart":0,"requestStart":520.1000000238419,"responseEnd":540.7999999523163,"responseStart":539.3999999761581,"secureConnectionStart":256.10000002384186},{"duration":550.6999999284744,"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":256.10000002384186,"connectEnd":256.10000002384186,"connectStart":256.10000002384186,"domainLookupEnd":256.10000002384186,"domainLookupStart":256.10000002384186,"fetchStart":256.10000002384186,"redirectEnd":0,"redirectStart":0,"requestStart":518.8999999761581,"responseEnd":806.7999999523163,"responseStart":537.8999999761581,"secureConnectionStart":256.10000002384186},{"duration":292.2000000476837,"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":256.1999999284744,"connectEnd":256.1999999284744,"connectStart":256.1999999284744,"domainLookupEnd":256.1999999284744,"domainLookupStart":256.1999999284744,"fetchStart":256.1999999284744,"redirectEnd":0,"redirectStart":0,"requestStart":527,"responseEnd":548.3999999761581,"responseStart":547.1000000238419,"secureConnectionStart":256.1999999284744},{"duration":293.89999997615814,"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":256.2999999523163,"connectEnd":256.2999999523163,"connectStart":256.2999999523163,"domainLookupEnd":256.2999999523163,"domainLookupStart":256.2999999523163,"fetchStart":256.2999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":527.5,"responseEnd":550.1999999284744,"responseStart":548.5,"secureConnectionStart":256.2999999523163},{"duration":273.60000002384186,"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":256.5,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":256.5,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":530.1000000238419,"responseStart":0,"secureConnectionStart":0},{"duration":296.39999997615814,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":256.60000002384186,"connectEnd":256.60000002384186,"connectStart":256.60000002384186,"domainLookupEnd":256.60000002384186,"domainLookupStart":256.60000002384186,"fetchStart":256.60000002384186,"redirectEnd":0,"redirectStart":0,"requestStart":533.1000000238419,"responseEnd":553,"responseStart":551.1999999284744,"secureConnectionStart":256.60000002384186},{"duration":275.40000009536743,"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":256.6999999284744,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":256.6999999284744,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":532.1000000238419,"responseStart":0,"secureConnectionStart":0},{"duration":298.60000002384186,"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":256.7999999523163,"connectEnd":256.7999999523163,"connectStart":256.7999999523163,"domainLookupEnd":256.7999999523163,"domainLookupStart":256.7999999523163,"fetchStart":256.7999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":535.6000000238419,"responseEnd":555.3999999761581,"responseStart":554.3999999761581,"secureConnectionStart":256.7999999523163},{"duration":527.2000000476837,"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":262.2999999523163,"connectEnd":262.2999999523163,"connectStart":262.2999999523163,"domainLookupEnd":262.2999999523163,"domainLookupStart":262.2999999523163,"fetchStart":262.2999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":595.1999999284744,"responseEnd":789.5,"responseStart":782.2999999523163,"secureConnectionStart":262.2999999523163},{"duration":530.1000000238419,"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":262.39999997615814,"connectEnd":262.39999997615814,"connectStart":262.39999997615814,"domainLookupEnd":262.39999997615814,"domainLookupStart":262.39999997615814,"fetchStart":262.39999997615814,"redirectEnd":0,"redirectStart":0,"requestStart":642.7999999523163,"responseEnd":792.5,"responseStart":786.1000000238419,"secureConnectionStart":262.39999997615814},{"duration":215.60000002384186,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":817.8999999761581,"connectEnd":817.8999999761581,"connectStart":817.8999999761581,"domainLookupEnd":817.8999999761581,"domainLookupStart":817.8999999761581,"fetchStart":817.8999999761581,"redirectEnd":0,"redirectStart":0,"requestStart":1001.6000000238419,"responseEnd":1033.5,"responseStart":1032.3999999761581,"secureConnectionStart":817.8999999761581},{"duration":217.80000007152557,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":1064.6999999284744,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1064.6999999284744,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1282.5,"responseStart":0,"secureConnectionStart":0}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":99,"responseStart":250,"responseEnd":257,"domLoading":254,"domInteractive":1258,"domContentLoadedEventStart":1258,"domContentLoadedEventEnd":1315,"domComplete":1691,"loadEventStart":1691,"loadEventEnd":1692,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1198.3999999761581},{"name":"bigPipe.sidebar-id.end","time":1199.1999999284744},{"name":"bigPipe.activity-panel-pipe-id.start","time":1199.3999999761581},{"name":"bigPipe.activity-panel-pipe-id.end","time":1201},{"name":"activityTabFullyLoaded","time":1330.7999999523163}],"measures":[],"correlationId":"2c1658bec2f424","effectiveType":"4g","downlink":9.2,"rtt":0,"serverDuration":86,"dbReadsTimeInMs":19,"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.