Ok, this patch updates select_lex->window_funcs.
But there is also st_select_lex::add_window_spec() called which populates st_select_lex::window_specs and changes other members...
Will we have to move those, too? (Please wait with coding this).
Sergei Petrunia
added a comment - Ok, this patch updates select_lex->window_funcs .
But there is also st_select_lex::add_window_spec() called which populates st_select_lex::window_specs and changes other members...
Will we have to move those, too? (Please wait with coding this).
Should we just delay the calls to
st_select_lex::add_window_spec()
st_select_lex::add_window_func()
until e.g. window function's fix_fields() call?
Possible issues here are:
fix_fields() is called on each statement execution
The above functions update st_select_lex::fields_in_window_functions. That member is used in st_select_lex::get_cardinality_of_ref_ptrs_slice(), which is called before fix_fields is called for Item_windowfunc objects.
Sergei Petrunia
added a comment - A suggestion considered in discussion with Sanja:
Should we just delay the calls to
st_select_lex::add_window_spec()
st_select_lex::add_window_func()
until e.g. window function's fix_fields() call?
Possible issues here are:
fix_fields() is called on each statement execution
The above functions update st_select_lex::fields_in_window_functions . That member is used in st_select_lex::get_cardinality_of_ref_ptrs_slice(), which is called before fix_fields is called for Item_windowfunc objects.
// psergey: here, we could modify the context so that window functions
// are listed somewhere else than the current select.
// for example Select->parse_win_function_data_here .
// (Note that this will still work if query_expression_tail has subqueries)
}
query_expression_tail
{
// Inside this function, in Lex_order_limit_lock::set_to,
// the data from Select->parse_win_function_data_here will be copied
// to the same select where ORDER BY clause is put.
if (!($$= Lex->add_tail_to_query_expression_body_ext_parens($1, $3)))
MYSQL_YYABORT;
}
This still looks messy. Maybe, it's easier to walk the parse tree and collect info about window functions?
Note that we will only have to walk the select list and order by. We won't need to walk into subqueries. We won't need to walk the WHERE clause, which can be large.
Sergei Petrunia
added a comment - - edited The problem part of the grammar, with my suggestion in comments:
| query_expression_body_ext_parens
{
Lex->push_select(!$1->first_select()->next_select() ?
$1->first_select() : $1->fake_select_lex);
// psergey: here, we could modify the context so that window functions
// are listed somewhere else than the current select.
// for example Select->parse_win_function_data_here .
// (Note that this will still work if query_expression_tail has subqueries)
}
query_expression_tail
{
// Inside this function, in Lex_order_limit_lock::set_to,
// the data from Select->parse_win_function_data_here will be copied
// to the same select where ORDER BY clause is put.
if (!($$= Lex->add_tail_to_query_expression_body_ext_parens($1, $3)))
MYSQL_YYABORT;
}
This still looks messy. Maybe, it's easier to walk the parse tree and collect info about window functions?
Note that we will only have to walk the select list and order by. We won't need to walk into subqueries. We won't need to walk the WHERE clause, which can be large.
At the parser stage, Window Functions should not "register" themselves in st_select_lex::window_funcs and st_select_lex::window_specs.
This should occur at a later stage, in JOIN::prepare, before the st_select_lex::get_cardinality_of_ref_ptrs_slice() call.
Walk the SELECT's select list and order by clause and collect the contents of st_select_lex::window_funcs and st_select_lex::window_specs.
Sergei Petrunia
added a comment - Final version of the fix suggestion:
At the parser stage, Window Functions should not "register" themselves in st_select_lex::window_funcs and st_select_lex::window_specs.
This should occur at a later stage, in JOIN::prepare, before the st_select_lex::get_cardinality_of_ref_ptrs_slice() call.
Walk the SELECT's select list and order by clause and collect the contents of st_select_lex::window_funcs and st_select_lex::window_specs.
As per psergei, the runtime team has taken over this ticket.
I think it makes sense, if the cause of the bug is the inconsistent attachments of Item_window_func to SELECT_LEX, resulted from actions during parsing / preparation.
Yuchen Pei
added a comment - - edited As per psergei , the runtime team has taken over this ticket.
I think it makes sense, if the cause of the bug is the inconsistent attachments of Item_window_func to SELECT_LEX, resulted from actions during parsing / preparation.
People
Unassigned
csfuzz
Votes:
2Vote for this issue
Watchers:
11Start watching this issue
Dates
Created:
Updated:
Git Integration
Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.
{"report":{"fcp":2065.199999809265,"ttfb":1026.1999998092651,"pageVisibility":"visible","entityId":126024,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"83d4d43c-fe76-4512-af24-0fdb19928e59","navigationType":0,"readyForUser":2159.5,"redirectCount":0,"resourceLoadedEnd":2488.699999809265,"resourceLoadedStart":1040.2999992370605,"resourceTiming":[{"duration":486.30000019073486,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":1040.2999992370605,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1040.2999992370605,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1526.5999994277954,"responseStart":0,"secureConnectionStart":0},{"duration":486.5,"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":1040.5999994277954,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1040.5999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1527.0999994277954,"responseStart":0,"secureConnectionStart":0},{"duration":540.2000007629395,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":1040.7999992370605,"connectEnd":1040.7999992370605,"connectStart":1040.7999992370605,"domainLookupEnd":1040.7999992370605,"domainLookupStart":1040.7999992370605,"fetchStart":1040.7999992370605,"redirectEnd":0,"redirectStart":0,"requestStart":1040.7999992370605,"responseEnd":1581,"responseStart":1580.8999996185303,"secureConnectionStart":1040.7999992370605},{"duration":607,"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":1041,"connectEnd":1041,"connectStart":1041,"domainLookupEnd":1041,"domainLookupStart":1041,"fetchStart":1041,"redirectEnd":0,"redirectStart":0,"requestStart":1041,"responseEnd":1648,"responseStart":1648,"secureConnectionStart":1041},{"duration":610.8000001907349,"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":1041.1999998092651,"connectEnd":1041.1999998092651,"connectStart":1041.1999998092651,"domainLookupEnd":1041.1999998092651,"domainLookupStart":1041.1999998092651,"fetchStart":1041.1999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":1041.1999998092651,"responseEnd":1652,"responseStart":1652,"secureConnectionStart":1041.1999998092651},{"duration":611.1999998092651,"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":1041.3999996185303,"connectEnd":1041.3999996185303,"connectStart":1041.3999996185303,"domainLookupEnd":1041.3999996185303,"domainLookupStart":1041.3999996185303,"fetchStart":1041.3999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":1041.3999996185303,"responseEnd":1652.5999994277954,"responseStart":1652.5999994277954,"secureConnectionStart":1041.3999996185303},{"duration":611.4000005722046,"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":1041.5999994277954,"connectEnd":1041.5999994277954,"connectStart":1041.5999994277954,"domainLookupEnd":1041.5999994277954,"domainLookupStart":1041.5999994277954,"fetchStart":1041.5999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":1041.5999994277954,"responseEnd":1653,"responseStart":1653,"secureConnectionStart":1041.5999994277954},{"duration":686.8999996185303,"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":1041.8999996185303,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1041.8999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1728.7999992370605,"responseStart":0,"secureConnectionStart":0},{"duration":611.6999998092651,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":1042.0999994277954,"connectEnd":1042.0999994277954,"connectStart":1042.0999994277954,"domainLookupEnd":1042.0999994277954,"domainLookupStart":1042.0999994277954,"fetchStart":1042.0999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":1042.0999994277954,"responseEnd":1653.7999992370605,"responseStart":1653.7999992370605,"secureConnectionStart":1042.0999994277954},{"duration":686.8000001907349,"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":1042.1999998092651,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1042.1999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1729,"responseStart":0,"secureConnectionStart":0},{"duration":612,"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":1042.3999996185303,"connectEnd":1042.3999996185303,"connectStart":1042.3999996185303,"domainLookupEnd":1042.3999996185303,"domainLookupStart":1042.3999996185303,"fetchStart":1042.3999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":1042.3999996185303,"responseEnd":1654.3999996185303,"responseStart":1654.3999996185303,"secureConnectionStart":1042.3999996185303},{"duration":1443.6999998092651,"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":1043.3999996185303,"connectEnd":1043.3999996185303,"connectStart":1043.3999996185303,"domainLookupEnd":1043.3999996185303,"domainLookupStart":1043.3999996185303,"fetchStart":1043.3999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":1043.3999996185303,"responseEnd":2487.0999994277954,"responseStart":2487.0999994277954,"secureConnectionStart":1043.3999996185303},{"duration":1441.1000003814697,"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":1047.5999994277954,"connectEnd":1047.5999994277954,"connectStart":1047.5999994277954,"domainLookupEnd":1047.5999994277954,"domainLookupStart":1047.5999994277954,"fetchStart":1047.5999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":1047.5999994277954,"responseEnd":2488.699999809265,"responseStart":2488.699999809265,"secureConnectionStart":1047.5999994277954},{"duration":481.30000019073486,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1746.3999996185303,"connectEnd":1746.3999996185303,"connectStart":1746.3999996185303,"domainLookupEnd":1746.3999996185303,"domainLookupStart":1746.3999996185303,"fetchStart":1746.3999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":1746.3999996185303,"responseEnd":2227.699999809265,"responseStart":2227.699999809265,"secureConnectionStart":1746.3999996185303}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":850,"responseStart":1026,"responseEnd":1039,"domLoading":1037,"domInteractive":2518,"domContentLoadedEventStart":2518,"domContentLoadedEventEnd":2567,"domComplete":2803,"loadEventStart":2803,"loadEventEnd":2803,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":2494.3999996185303},{"name":"bigPipe.sidebar-id.end","time":2495.199999809265},{"name":"bigPipe.activity-panel-pipe-id.start","time":2495.3999996185303},{"name":"bigPipe.activity-panel-pipe-id.end","time":2497.5},{"name":"activityTabFullyLoaded","time":2586}],"measures":[],"correlationId":"cd0a33096c5c08","effectiveType":"4g","downlink":9.9,"rtt":0,"serverDuration":113,"dbReadsTimeInMs":14,"dbConnsTimeInMs":24,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
Ok, this patch updates select_lex->window_funcs.
But there is also st_select_lex::add_window_spec() called which populates st_select_lex::window_specs and changes other members...
Will we have to move those, too? (Please wait with coding this).