mirror of
https://github.com/FirebirdSQL/firebird-qa.git
synced 2025-01-22 13:33:07 +01:00
49 lines
1.2 KiB
Python
49 lines
1.2 KiB
Python
#coding:utf-8
|
|
|
|
"""
|
|
ID: issue-5429
|
|
ISSUE: 5429
|
|
TITLE: Suboptimal join order if one table has a selective predicate and MIN is calculated for the other one
|
|
DESCRIPTION:
|
|
JIRA: CORE-5146
|
|
FBTEST: bugs.core_5146
|
|
"""
|
|
|
|
import pytest
|
|
from firebird.qa import *
|
|
|
|
db = db_factory()
|
|
|
|
test_script = """
|
|
-- Confirmed:
|
|
-- effective plan on: V3.0.0.32435, T4.0.0.113
|
|
-- ineffect. plan on: V3.0.0.32378, T4.0.0.98
|
|
|
|
recreate table houritems(houritemid int, projectid int); -- hi
|
|
recreate table dihourentries(houritemid int, datevalue int); -- he
|
|
|
|
create index hi_itemid on houritems(houritemid);
|
|
create index hi_projid on houritems(projectid);
|
|
create index he_itemid on dihourentries(houritemid);
|
|
create index he_datevl on dihourentries(datevalue);
|
|
|
|
set planonly;
|
|
|
|
select min(he.datevalue)
|
|
from houritems hi inner join dihourentries he on hi.houritemid = he.houritemid
|
|
where hi.projectid = ?;
|
|
"""
|
|
|
|
act = isql_act('db', test_script)
|
|
|
|
expected_stdout = """
|
|
PLAN JOIN (HI INDEX (HI_PROJID), HE INDEX (HE_ITEMID))
|
|
"""
|
|
|
|
@pytest.mark.version('>=3.0')
|
|
def test_1(act: Action):
|
|
act.expected_stdout = expected_stdout
|
|
act.execute()
|
|
assert act.clean_stdout == act.clean_expected_stdout
|
|
|